国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue.js中用v-bind綁定class的注意事項

2019-11-19 18:32:13
字體:
來源:轉載
供稿:網友

前言

在Vue.js版本:1.0.27,使用Vue.js中V-bind指令來綁定class和style時,Vue.js對其進行了增強。表達式結果出了字符串之外,還可以是對象或者數組。

這里自己對其進行了測試,發現有一下的問題:

如果使用對象語法對class進行綁定話,class名稱必須加上引號,代表所對應的樣式,否則會將其當做對象的屬性,從而使得初始化報錯。

<!DOCTYPE html> <html lang="en">  <head>  <meta charset="UTF-8">  <title>Document</title>  <script src="http://cdn.bootcss.com/vue/1.0.27/vue.js"></script>  <style>  .static {  font-size: 120px;  width: 600px;  margin: 0 auto;  background-color: yellow;  height: 120px;  line-height: 120px;  text-align: center;  }   .class-a {  color: #FF0000;  }   .class-b {  text-decoration: underline;  }  </style> </head>  <body>  <div id="app">  <div v-bind:class="classObject">  關于class的綁定  </div>  </div>  <script>  var vm = new Vue({  el: '#app',  data: {  classObject: {  //'class-a',不能寫成class-a(不帶引號);這里的classObject是js對象,而class-b是代表的是一個樣式,所以必須寫成'class-a',用引號括起來。  //否則這里的class-a只能代表classObject的一個屬性名稱而已,這樣vuejs在初始化時,會報錯。  'class-a':false,  'class-b': true  }  }  });  </script> </body>  </html> 

參考資料:

Vue.js官網----http://cn.vuejs.org/guide/class-and-style.html

補充:

在這里,自己感覺代碼中的classObject有點像散列表,key是一個樣式class,而value是boolean類型的值。

從console中獲取和改變classObject對象中class-a值,見下圖:

看到console中操作,讓我覺得對于classObject確實有點像散列表類型。為了證實這個,可以去看看源碼(ps:自己沒看)。

在Vue.js1.0.19,作者為其添加了一些語法,在數組也可以使用對象語法:

<div v-bind:class="[classA, { 'classB': isB, 'classC': isC }]">class綁定</div>

<div v-bind:class="[classA, { classB: isB, classC: isC }]">class綁定</div>

上面,對于classA可以加引號和不加引號,下面是自己的測試代碼。

<!DOCTYPE html> <html lang="en">  <head>  <meta charset="UTF-8">  <title>Document</title>  <script src="http://cdn.bootcss.com/vue/1.0.27/vue.js"></script>  <style>  .static {  font-size: 120px;  width: 600px;  margin: 0 auto;  background-color: yellow;  height: 120px;  line-height: 120px;  text-align: center;  }   .class-a {  color: #FF0000;  }   .classB {  text-decoration: underline;  }   .classC{  text-shadow: 2px 2px 4px #000000;  }  </style> </head>  <body>  <div id="app">  <!-- 兩種綁定:加引號和不加引號,都可以 -->  <div v-bind:class="[classA, { 'classB': isB, 'classC': isC }]">class綁定</div>  <div v-bind:class="[classA, { classB: isB, classC: isC }]">class綁定</div>  </div>  <script>  var vm = new Vue({  el: '#app',  data: {  classA: 'class-a',  isB: true,  isC: true  }   });  </script> </body>  </html> 

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 江油市| 桦甸市| 商南县| 团风县| 孙吴县| 金秀| 铜梁县| 新宾| 牙克石市| 盱眙县| 岑巩县| 磐石市| 天气| 莱阳市| 泰顺县| 桃园市| 清河县| 金沙县| 宜宾市| 墨竹工卡县| 米泉市| 宕昌县| 永川市| 临江市| 宁陵县| 会东县| 枣强县| 高青县| 昌平区| 盐津县| 天长市| 桦南县| 万年县| 寻乌县| 台前县| 土默特右旗| 德保县| 天门市| 绥棱县| 水富县| 怀宁县|