ホームページ > ウェブフロントエンド > jsチュートリアル > VueJs における V-bind ディレクティブのユースケースの分析

VueJs における V-bind ディレクティブのユースケースの分析

php中世界最好的语言
リリース: 2018-06-01 11:44:07
オリジナル
1785 人が閲覧しました

今回は、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 属性を使用する場合、これらのクラスは上記のコンポーネントのルート要素に追加されます。この要素にすでに存在するクラスは上書きされません。たとえば、このコンポーネントを

<p v-bind:class="[isActive ? activeClass : &#39;&#39;, errorClass]"></p>
ログイン後にコピー

と宣言し、それを使用するときに Class

<p v-bind:class="[{ active: isActive }, errorClass]"></p>
ログイン後にコピー

HTML を追加すると、次のようにレンダリングされます:

Rreee

for data binding class isActive が true の場合、HTML は次のようになります

Vue.component('my-component', {
 template: '<p class="foo bar">Hi</p>'
})
ログイン後にコピー

としてレンダリングされます。 4. インライン スタイルのバインド

オブジェクト構文

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

JavaScript

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

<my-component class="baz boo"></my-component>
ログイン後にコピー

通常、スタイル オブジェクトに直接バインドする方が良いため、テンプレートがより明確になります

同様に、オブジェクト構文は次のとおりです。返されたオブジェクトの計算されたプロパティと組み合わせてよく使用されます

配列構文

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

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

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

推荐阅读:

使用JS判断字符串中包含内容方法总结

JS+HTML5实绑定鼠标事件的粒子动画

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

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