Vue是一種基于MVVM模式的JavaScript框架,它使得前端開發(fā)工作更加高效和快捷。Vue的核心之一就是數(shù)據(jù)綁定,在Vue中我們可以使用data屬性來聲明數(shù)據(jù)。
var vm = new Vue({
data: {
message: 'Hello World!'
}
})
上面的代碼中,我們創(chuàng)建一個Vue實(shí)例并聲明了一個data屬性,內(nèi)部包含一個名為message的屬性。如果我們要使用這個屬性,只需要使用{{}}插值即可:
{{ message }}
當(dāng)message屬性的值發(fā)生改變時,插值也會自動更新。這樣我們可以將數(shù)據(jù)與視圖進(jìn)行綁定,實(shí)現(xiàn)數(shù)據(jù)驅(qū)動。
除了簡單的字符串類型,我們還可以聲明更加復(fù)雜的數(shù)據(jù)類型,比如對象、數(shù)組等:
var vm = new Vue({
data: {
user: {
name: '張三',
age: 18,
address: {
province: '浙江省',
city: '杭州市',
district: '西湖區(qū)'
}
},
books: [
{ title: 'Vue.js實(shí)戰(zhàn)', author: '張三', price: 19.99 },
{ title: 'JavaScript高級程序設(shè)計', author: '李四', price: 29.99 },
{ title: 'Node.js實(shí)戰(zhàn)', author: '王五', price: 24.99 }
]
}
})
我們可以通過this來訪問這些數(shù)據(jù):
console.log(this.user.name) //張三
console.log(this.books[0].title) //Vue.js實(shí)戰(zhàn)
在Vue中聲明的數(shù)據(jù)會被Vue轉(zhuǎn)換成getter和setter,這樣Vue就可以跟蹤數(shù)據(jù)的變化并在適當(dāng)?shù)臅r候更新DOM,保證了數(shù)據(jù)與視圖的同步。
值得注意的是,一旦Vue實(shí)例被創(chuàng)建,就不能再添加新的屬性或刪除已有屬性。如果需要動態(tài)添加屬性,可以使用Vue.set方法或者使用響應(yīng)式的對象,但不建議直接對data對象進(jìn)行修改。