深入對Vue.js $watch方法的理解
博主最近對著vue.js的官方教程在自學(xué)vue.js,博主自幼愚鈍,在教程中真的是好多點都不太理解,接下來要說的這個$watch方法就是其中一個不太理解的點了。咱們先來看一下對于$watch方法在vue.js的API中是怎么解釋的吧:觀察 Vue 實例變化的一個表達式或計算屬性函數(shù)。回調(diào)函數(shù)得到的參數(shù)為新值和舊值。表達式只接受監(jiān)督的鍵路徑。對于更復(fù)雜的表達式,用一個函數(shù)取代。官方示例:
// 鍵路徑
vm.$watch('a.b.c', function (newVal, oldVal) {
// 做點什么
})
// 函數(shù)
vm.$watch(
function () {
return this.a + this.b
},
function (newVal, oldVal) {
// 做點什么
}
)
vm.$watch 返回一個取消觀察函數(shù),用來停止觸發(fā)回調(diào):
var unwatch = vm.$watch('a', cb)
// 之后取消觀察
unwatch()
博主很認(rèn)真地看了看,當(dāng)時就懵逼了,沒看懂。還好網(wǎng)上大神多,查了查終于搞明白這個$watch方法的用法了。說白了$watch這貨就是觀察一個值的變化,觀察的這個值一變化的話,那么就執(zhí)行function里面的語句。廢話不多說,咱們直接看代碼:
HTML:
<div id="watch">
firstName:<input type="text" name="li" v-model="firstName">
<br>
lastName:<input type="text" name="fei" v-model="lastName">
<p>fullName: {{fullName}}</p>
</div>
JS:
var vm = new Vue({
el: '#watch',
data: {
firstName: 'a',
lastName: 'fei',
fullName: 'a fei'
},
watch: {
firstName: function (val) {
this.fullName = val + ' ' + this.lastName
},
lastName: function (val) {
this.fullName = this.firstName + ' ' + val
}
}
})
在代碼中,我們用wach方法監(jiān)聽了firstName和lastName這兩個變量,我們在input框框那里做了雙綁定,這樣子的話,我們在firstName輸入框中輸入的值就會改變變量firstName的值,同理可得lastName,因為值的改變和watch這貨的觀察,所以watch里面的function代碼就會運行,這樣子fullName也就會相應(yīng)地改變了。這樣子$watch這方法的用法也就一下子明了了。上述的例子中$watch就和原生js里面的on-change差不多了。
以上就是博主對$watch方法的理解了,希望可以幫助大家理解這一方法,要是上述有何不對的地方,麻煩各位看官多多指出,謝謝大家。
相關(guān)文章
基于vue循環(huán)列表時點擊跳轉(zhuǎn)頁面的方法
今天小編就為大家分享一篇基于vue循環(huán)列表時點擊跳轉(zhuǎn)頁面的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
vue+intro.js插件實現(xiàn)引導(dǎo)功能
使用 intro.js這個插件,來實現(xiàn)一個引導(dǎo)性的效果,經(jīng)常在一些新手引導(dǎo)頁遇到這樣的需求,下面通過本文給大家分享vue+intro.js插件實現(xiàn)引導(dǎo)功能,感興趣的朋友一起看看吧2024-06-06
vue3語法中使用vscode打開滿屏紅線報錯的完美解決方法
這篇文章主要介紹了vue3語法中使用vscode打開滿屏紅線報錯的完美解決方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06
karma+webpack搭建vue單元測試環(huán)境的方法示例
本篇文章主要介紹了karma+webpack搭建vue單元測試環(huán)境的方法示例,這次搭建的測試環(huán)境和開發(fā)環(huán)境隔離,所以理論上適用所有使用vue的開發(fā)環(huán)境。感興趣的小伙伴們可以參考一下2018-05-05

