Vue.js中用v-bind綁定class的注意事項(xiàng)
前言
在Vue.js版本:1.0.27,使用Vue.js中V-bind指令來(lái)綁定class和style時(shí),Vue.js對(duì)其進(jìn)行了增強(qiáng)。表達(dá)式結(jié)果出了字符串之外,還可以是對(duì)象或者數(shù)組。
這里自己對(duì)其進(jìn)行了測(cè)試,發(fā)現(xiàn)有一下的問(wèn)題:
如果使用對(duì)象語(yǔ)法對(duì)class進(jìn)行綁定話,class名稱必須加上引號(hào),代表所對(duì)應(yīng)的樣式,否則會(huì)將其當(dāng)做對(duì)象的屬性,從而使得初始化報(bào)錯(cuò)。
<!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(不帶引號(hào));這里的classObject是js對(duì)象,而class-b是代表的是一個(gè)樣式,所以必須寫成'class-a',用引號(hào)括起來(lái)。
//否則這里的class-a只能代表classObject的一個(gè)屬性名稱而已,這樣vuejs在初始化時(shí),會(huì)報(bào)錯(cuò)。
'class-a':false,
'class-b': true
}
}
});
</script>
</body>
</html>
參考資料:
Vue.js官網(wǎng)----http://cn.vuejs.org/guide/class-and-style.html
補(bǔ)充:
在這里,自己感覺(jué)代碼中的classObject有點(diǎn)像散列表,key是一個(gè)樣式class,而value是boolean類型的值。
從console中獲取和改變classObject對(duì)象中class-a值,見(jiàn)下圖:

看到console中操作,讓我覺(jué)得對(duì)于classObject確實(shí)有點(diǎn)像散列表類型。為了證實(shí)這個(gè),可以去看看源碼(ps:自己沒(méi)看)。
在Vue.js1.0.19,作者為其添加了一些語(yǔ)法,在數(shù)組也可以使用對(duì)象語(yǔ)法:
<div v-bind:class="[classA, { 'classB': isB, 'classC': isC }]">class綁定</div>
<div v-bind:class="[classA, { classB: isB, classC: isC }]">class綁定</div>
上面,對(duì)于classA可以加引號(hào)和不加引號(hào),下面是自己的測(cè)試代碼。
<!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">
<!-- 兩種綁定:加引號(hào)和不加引號(hào),都可以 -->
<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é)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
vue 通過(guò)綁定事件獲取當(dāng)前行的id操作
這篇文章主要介紹了vue 通過(guò)綁定事件獲取當(dāng)前行的id操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
Vue生命周期和鉤子函數(shù)的詳解與經(jīng)典面試題
Vue生命周期是指vue實(shí)例對(duì)象從創(chuàng)建之初到銷毀的過(guò)程,vue所有功能的實(shí)現(xiàn)都是圍繞其生命周期進(jìn)行的,下面這篇文章主要給大家介紹了關(guān)于Vue生命周期和鉤子函數(shù)的相關(guān)資料,需要的朋友可以參考下2021-10-10
關(guān)于vuex狀態(tài)刷新網(wǎng)頁(yè)時(shí)數(shù)據(jù)被清空問(wèn)題及解決
這篇文章主要介紹了關(guān)于vuex狀態(tài)刷新網(wǎng)頁(yè)時(shí)數(shù)據(jù)被清空問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
watch里面的deep和immediate作用及說(shuō)明
這篇文章主要介紹了watch里面的deep和immediate作用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
vue中的導(dǎo)航守衛(wèi)使用及說(shuō)明
這篇文章主要介紹了vue中的導(dǎo)航守衛(wèi)使用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
解決webpack+Vue引入iView找不到字體文件的問(wèn)題
今天小編就為大家分享一篇解決webpack+Vue引入iView找不到字體文件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Vue3.2.x中的小技巧及注意事項(xiàng)總結(jié)
Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式JavaScript框架,是目前最火的前端框架之一,是前端工程師的必備技能,下面這篇文章主要給大家介紹了關(guān)于Vue3.2.x中的小技巧及注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2022-04-04
Vue3?Composition?API優(yōu)雅封裝第三方組件實(shí)例
這篇文章主要為大家介紹了Vue3?Composition?API優(yōu)雅封裝第三方組件實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07

