Vue.js中用v-bind綁定class的注意事項
前言
在Vue.js版本:1.0.27,使用Vue.js中V-bind指令來綁定class和style時,Vue.js對其進(jìn)行了增強(qiáng)。表達(dá)式結(jié)果出了字符串之外,還可以是對象或者數(shù)組。
這里自己對其進(jìn)行了測試,發(fā)現(xiàn)有一下的問題:
如果使用對象語法對class進(jìn)行綁定話,class名稱必須加上引號,代表所對應(yīng)的樣式,否則會將其當(dāng)做對象的屬性,從而使得初始化報錯。
<!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"> 關(guān)于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官網(wǎng)----http://cn.vuejs.org/guide/class-and-style.html
補(bǔ)充:
在這里,自己感覺代碼中的classObject有點像散列表,key是一個樣式class,而value是boolean類型的值。
從console中獲取和改變classObject對象中class-a值,見下圖:
看到console中操作,讓我覺得對于classObject確實有點像散列表類型。為了證實這個,可以去看看源碼(ps:自己沒看)。
在Vue.js1.0.19,作者為其添加了一些語法,在數(shù)組也可以使用對象語法:
<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>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
vue使用天地圖、openlayers實現(xiàn)多個底圖疊加顯示效果
這篇文章主要介紹了vue使用天地圖、openlayers實現(xiàn)多個底圖疊加顯示,根據(jù)返回的經(jīng)緯度列表通過天地圖、openlayers實現(xiàn)底圖添加,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2022-04-04