ホームページ > ウェブフロントエンド > フロントエンドQ&A > vue での v-bind の用途は何ですか

vue での v-bind の用途は何ですか

青灯夜游
リリース: 2022-12-15 10:24:43
オリジナル
4435 人が閲覧しました

vue では、v-bind 命令は主に属性バインディングに使用されます。完全な構文 "v-bind:property="value"" と省略された構文 ":href="value"" は、属性は変数として扱われ、Vue はそれを解析し、解析された変数をデータ属性の対応する値に割り当てます。

vue での v-bind の用途は何ですか

#このチュートリアルの動作環境: Windows7 システム、vue3 バージョン、DELL G3 コンピューター。

vue の v-bind の概要

v-bind は主に、クラス属性、スタイル属性、 value 属性、href 属性など、属性である限り、v-bind ディレクティブを使用してバインドできます。

v-bind は主に属性バインディングに使用されます。Vue では公式に次のような略語:bind が提供されています:

<!-- 完整语法 -->
v-bind:property="value"
//此时 value会被解析成一个变量,若是在vue实例中没有找到,会显示找不到错误


<!-- 缩写 -->
:href="value"
ログイン後にコピー

v-bind を追加すると、属性の属性値が次のようになります。変数 Vue はそれを解析し、解析された変数をデータ属性の対応する値に割り当てます。

バインディング HTML クラス

1. オブジェクト構文:

v-bind を指定できます。 :class クラスを動的に切り替えるためのオブジェクト。注: v-bind:class ディレクティブは通常のクラス属性と共存できます

HTML コード:

<ul class="box" v-bind:class="{‘textColor‘:isColor, ‘textSize‘:isSize}">
    <li>学习Vue</li>
    <li>学习Node</li>
    <li>学习React</li>
</ul>
ログイン後にコピー

CSS コード:

.box{
    border:1px dashed #f0f;
}
.textColor{
    color:#f00;
    background-color:#eef;
}
.textSize{
    font-size:30px;
    font-weight:bold;
}
ログイン後にコピー

JS コード:

var vm= new Vue({
    el:‘.box‘,
    data:{
        isColor:true,
        isSize:true
    }
})
ログイン後にコピー

vue での v-bind の用途は何ですか

図からわかるように、HTML は最終的に

    isColor と isSize としてレンダリングされます。たとえば、 isSize が false に変更された場合、クラス リストは

      になります。直接バインドすることもできます 指定したデータ内のオブジェクト:

      HTML コード:

      <ul class="box" :class="classObject">
          <li>学习Vue</li>
          <li>学习Node</li>
          <li>学习React</li>
      </ul>
      ログイン後にコピー

      JS コード:

      var vm= new Vue({
          el:‘.box‘,
          data:{
              classObject:{
                  ‘textColor‘:true,
                  ‘textSize‘:false //不渲染,注意看下面的截图
              }
          }
      })
      ログイン後にコピー

      vue での v-bind の用途は何ですか

      ## 2. 配列構文

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

      HTML コード:

      <ul class="box" :class="[classA, classB]">
          <li>学习Vue</li>
          <li>学习Node</li>
          <li>学习React</li>
      </ul>
      ログイン後にコピー

      JSコード:

      var vm= new Vue({
          el:‘.box‘,
          data:{
              classA:‘textColor‘,
              classB:‘textSize‘
          }
      })
      ログイン後にコピー

      条件に基づいてリスト内のクラスを切り替えたい場合は、三項算術

      HTML コード:

      <ul class="box" :class="[isA?classA:‘‘, classB]">
          <li>学习Vue</li>
          <li>学习Node</li>
          <li>学习React</li>
      </ul>
      ログイン後にコピー

      JS を使用できます。コード:

      var vm= new Vue({
          el:‘.box‘,
          data:{
              classA:‘textColor‘,
              classB:‘textSize‘,
              isA:false 
          }
      })
      ログイン後にコピー

      この例では、最初に isA のブール値を決定します。これが true の場合は classA が表示され、false の場合は表示されません。 ClassB は三項演算を実行しないので、常に表示されます。ページのスクリーンショットを見てください。

      vue での v-bind の用途は何ですか

      複数のクラスの場合、次のように記述できます:

      <div v-bind:class="[classA, { classB: isB, classC: isC }]">
      ログイン後にコピー

      バインド インライン スタイル

      1. オブジェクト構文

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

      CSS プロパティ名はキャメル ケースを使用する必要があります

      (公式ドキュメントでは、キャメル ケースまたはダッシュ区切りの命名法を使用できると記載されています)ただし、ダッシュで区切るとエラーが報告されます。 HTML コード: (これは、ダッシュで区切られた CSS 属性名のデモです。エラーが報告されます)

      <div id="box" :style="{color:activeColor, font-size:size}">红嘴绿鹦哥</div>
      ログイン後にコピー

      JS コード:

      var vm= new Vue({
          el:‘#box‘,
          data:{
              activeColor:‘#f00‘,
              size:‘30px‘,
              shadow:‘5px 2px 6px #000‘
          }
      })
      ログイン後にコピー

      ページ エラー:

      vue での v-bind の用途は何ですかキャメル ケースの命名規則に従って記述すると、すべてが正常です:

      HTML コード:

      <div id="box" :  style="max-width:90%">红嘴绿鹦哥</div>
      ログイン後にコピー
      ログイン後にコピー

      ページ効果の表示:

      vue での v-bind の用途は何ですか## スタイル オブジェクトに直接バインドすることもできます。どちらの方が優れており、テンプレートが明確になります:

      HTML コード:

      <div id="box" :  style="max-width:90%">红嘴绿鹦哥</div>
      ログイン後にコピー
      ログイン後にコピー

      JS コード:

      var vm= new Vue({
          el:‘#box‘,
          data:{
              styleObject:{
                  color:‘red‘,
                  fontSize:‘30px‘
              }
          }
      })
      ログイン後にコピー

      2. 配列構文

      1 つの要素に複数のスタイル オブジェクトを適用できます

      HTML コード:

      <div class="box" :style="[styleObjectA, styleObjectB]">好好学习,天天向上</div>
      ログイン後にコピー

      JS コード:

      var vm2= new Vue({
          el:‘.box‘,
          data:{
              styleObjectA:{
                  fontSize:‘36px‘,
                  color:‘blue‘
              },
              styleObjectB:{
                  textDecoration:‘underline‘
              }
          }
      })
      ログイン後にコピー

      ページ効果:

      vue での v-bind の用途は何ですか画像 SRC アドレスの追加

      img タグの src 属性に値を割り当てるときは、従来の方法 {{url}} に従います:

      HTML コード:

      <img  class="box" src="{{url}}"  alt="vue での v-bind の用途は何ですか" >
      ログイン後にコピー
      JS コード:

      var vm= new Vue({
          el:‘.box‘,
          data:{
              url:‘https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc76vue での v-bind の用途は何ですか‘
          }
      })
      ログイン後にコピー
      この時点では画像は正常に表示できますが、ただし、404 エラーが報告されます。コンソールを見ればわかります。Vue を使用することをお勧めします。v-bind:src

      使用 v-bind:src 再来试试看

      HTML代码:

      <img  class="box" :src="url"  alt="vue での v-bind の用途は何ですか" >
      ログイン後にコピー

      查看页面截图:

      vue での v-bind の用途は何ですか

      【相关推荐:vuejs视频教程web前端开发

      以上がvue での v-bind の用途は何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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