Vue的watch深受開發(fā)者的青睞。在Vue中,我們可以通過watch屬性來監(jiān)聽數(shù)據(jù)變化,并且在數(shù)據(jù)變化后觸發(fā)指定的函數(shù)。watch能夠幫助我們實(shí)現(xiàn)一些比較復(fù)雜的邏輯操作,比如在數(shù)據(jù)變化時(shí)更新視圖,更新其他數(shù)據(jù)等。下面我們就來詳細(xì)講解一下Vue的watch調(diào)用函數(shù)。
首先,我們需要在Vue中定義一個(gè)watch屬性。watch屬性需要是一個(gè)對象,對象中的每一個(gè)屬性都是需要監(jiān)聽的數(shù)據(jù)變化和對應(yīng)的函數(shù)。比如,我們需要監(jiān)聽data中的text1和text2兩個(gè)數(shù)據(jù)變化,并且在數(shù)據(jù)變化后分別觸發(fā)對應(yīng)的函數(shù)func1和func2,那么watch屬性的定義如下:
watch: { text1: function() { this.func1(); }, text2: function() { this.func2(); } }
這里需要注意的是,在watch屬性中,我們需要定義一個(gè)函數(shù)來處理數(shù)據(jù)變化。同時(shí),在此函數(shù)中,this指向的是Vue實(shí)例本身。由于函數(shù)中可能會(huì)修改data中的數(shù)據(jù),因此在函數(shù)中我們可以通過this來訪問Vue實(shí)例中的其他方法和數(shù)據(jù)。
除了可以監(jiān)聽普通的數(shù)據(jù)變化外,Vue的watch還可以監(jiān)聽數(shù)組和對象的變化。當(dāng)我們需要監(jiān)聽數(shù)組中某一個(gè)元素的變化時(shí),可以使用Vue提供的$watch方法。$watch方法的第一個(gè)參數(shù)是需要監(jiān)聽的數(shù)組元素,第二個(gè)參數(shù)是數(shù)組元素變化后的回調(diào)函數(shù)。
this.$watch('array[0]', function() { console.log('數(shù)組元素變化啦!'); })
當(dāng)然,在使用$watch方法監(jiān)聽數(shù)組時(shí),需要注意數(shù)組元素的變化是不能觸發(fā)watch屬性的。因此,我們需要使用$set方法來更新數(shù)組元素,才能夠觸發(fā)watch屬性。
在watch中定義的函數(shù)可以擁有多個(gè)參數(shù),其中第一個(gè)參數(shù)是變化后的值,第二個(gè)參數(shù)是變化前的值。這樣我們就可以根據(jù)這些值來做一些操作,比如判斷數(shù)據(jù)變化的類型、更新其他數(shù)據(jù)等。
watch: { text1: function(newVal, oldVal) { if(newVal === '') { this.text2 = ''; } } }
最后需要注意的是,watch屬性的效率比computed屬性低。因?yàn)閣atch是每次數(shù)據(jù)變化都需要重新計(jì)算,而computed是只有在相關(guān)數(shù)據(jù)變化時(shí)才會(huì)重新計(jì)算。因此,在使用watch時(shí),需要注意不要在watch中操作耗時(shí)的操作,可以使用computed來替代watch,提高應(yīng)用的性能。