ホームページ > ウェブフロントエンド > jsチュートリアル > VueJs で V-bind ディレクティブを使用する方法

VueJs で V-bind ディレクティブを使用する方法

php中世界最好的语言
リリース: 2018-05-14 13:57:15
オリジナル
3061 人が閲覧しました

今回は、VueJs で V-bind 命令を使用する方法を説明します。VueJs で V-bind 命令を使用する際の 注意事項 は何ですか? 以下は実際的なケースです。

はじめに

v-bind は主に属性バインディングに使用されます。Vue は公式に略語としてバインドを提供します。例:

<!-- 完整语法 -->
<a v-bind:href="url"></a>
<!-- 缩写 -->
<a :href="url"></a>
ログイン後にコピー

1. 概要

v-bind は主に属性に使用されます。 class 属性、style 属性、value 属性、href 属性などのバインディングは、属性である限り、v-bind 命令を使用してバインドできます。

存在するかどうかは、データ属性 isActive の真偽に依存します

オブジェクトにさらに多くの属性を渡して、複数のクラスを動的に切り替えることができます。さらに、v-bind:class ディレクティブは、通常のクラス属性と共存することもできます。次のテンプレートがある場合:

<!-- 绑定一个属性 -->
<img v-bind:src="imageSrc">
<!-- 缩写 -->
<img :src="imageSrc">
<!-- 内联字符串拼接 -->
<img :src="&#39;/path/to/images/&#39; + fileName">
<!-- class 绑定 -->
<p :class="{ red: isRed }"></p>
<p :class="[classA, classB]"></p>
<p :class="[classA, { classB: isB, classC: isC }]">
<!-- style 绑定 -->
<p :style="{ fontSize: size + &#39;px&#39; }"></p>
<p :style="[styleObjectA, styleObjectB]"></p>
<!-- 绑定一个有属性的对象 -->
<p v-bind="{ id: someProp, &#39;other-attr&#39;: otherProp }"></p>
<!-- 通过 prop 修饰符绑定 DOM 属性 -->
<p v-bind:text-content.prop="text"></p>
<!-- prop 绑定。“prop”必须在 my-component 中声明。-->
<my-component :prop="someThing"></my-component>
<!-- 通过 $props 将父组件的 props 一起传给子组件 -->
<child-component v-bind="$props"></child-component>
<!-- XLink -->
<svg><a :xlink:special="foo"></a></svg>
ログイン後にコピー
結果は次のようにレンダリングされます:
<p v-bind:class="{ active: isActive }"></p>
ログイン後にコピー
isActive または hasError が変更されると、それに応じてクラス リストが更新されます。たとえば、hasError の値が true の場合、クラス リストは「static active text-danger」になります
バインドされたデータ オブジェクトはテンプレート内でインラインで定義する必要はありません

<p class="static"
  v-bind:class="{ active: isActive, &#39;text-danger&#39;: hasError }">
</p>
  和如下 data
data: {
 isActive: true,
 hasError: false
}
ログイン後にコピー
レンダリング結果は上記と同じです。ここで、返されたオブジェクトの計算されたプロパティをバインドすることもできます。これは一般的で強力なパターンです:

<p class="static active"></p>
ログイン後にコピー

配列構文

配列を v-bind:class に渡してクラス リストを適用できます

<p v-bind:class="classObject"></p>
data: {
 classObject: {
 active: true,
 'text-danger': false
 }
}
ログイン後にコピー
次のようにレンダリングされます:

<p v-bind:class="classObject"></p>
data: {
 isActive: true,
 error: null
},
computed: {
 classObject: function () {
 return {
  active: this.isActive && !this.error,
  'text-danger': this.error && this.error.type === 'fatal'
 }
 }
}
ログイン後にコピー
条件に基づいてリスト内のクラスを切り替えるには、三項

expression

<p v-bind:class="[activeClass, errorClass]"></p>
data: {
 activeClass: 'active',
 errorClass: 'text-danger'
}
ログイン後にコピー
を使用できます。この方法では、errorClass は常に追加されますが、activeClass は isActive が true の場合にのみ追加されます。 ただし、条件クラスが複数ある場合にこのように書くのは少し面倒です。したがって、オブジェクト構文は配列構文でも使用できます
<p class="active text-danger"></p>
ログイン後にコピー

3. コンポーネントで使用されます

自己定義コンポーネントで class 属性を使用する場合、これらのクラスは上記のコンポーネントのルート要素に追加されます。この要素にすでに存在するクラスは上書きされません。

このコンポーネントを宣言すると、次のようになります。

isActive が true の場合、HTML は

<p v-bind:class="[isActive ? activeClass : &#39;&#39;, errorClass]"></p>
ログイン後にコピー
としてレンダリングされます。

4. インラインスタイルのバインド

オブジェクト構文

v-bind:style のオブジェクト構文は非常に複雑です直感的 - CSS に非常によく似ていますが、実際には JavaScript

オブジェクトです。 CSS プロパティ名は、キャメルケースまたはケバブケースを使用して名前を付けることができます (一重引用符で囲むことを忘れないでください):

<p v-bind:class="[{ active: isActive }, errorClass]"></p>
ログイン後にコピー
通常、スタイル オブジェクトに直接バインドする方が良いため、テンプレートがより明確になります

Vue.component('my-component', {
 template: '<p class="foo bar">Hi</p>'
})
ログイン後にコピー
同様に、オブジェクト構文は次のとおりです。返されたオブジェクトの計算されたプロパティと組み合わせてよく使用されます

配列構文

   v-bind:style 的数组语法可以将多个样式对象应用到同一个元素上

<p v-bind:style="[baseStyles, overridingStyles]"></p>
ログイン後にコピー

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

react router4+redux控制路由权限步骤详解

v-bind与v-on使用案例详解

Vue表单类父子组件数据传递数据方法总结

以上がVueJs で V-bind ディレクティブを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート