1、watch使用的幾種方法
(1)通過watch監聽data資料的變化,資料發生變化時,就會列印目前的值
watch: {
data(val, newval) {
console.log(val)
console.log(newval)
}
}
(2)通過watch監聽docData資料的變化,資料發生變化時,this.change_number++(使用深度監聽)
watch: {
docData: {
handler(newVal) {
this.change_number++
},
deep: true
}
}
(3)通過watch監聽data資料的變化,資料發生變化時,執行changeData方法
watch: {
data: 'changeData' // 值可以為methods的方法名
},
methods: {
changeData(curVal,oldVal){
conosle.log(curVal,oldVal)
}
}
2、詳解watch中的immediate、handler和deep屬性
(1)immediate和handler
這樣使用watch時有一個特點,就是當值第一次綁定時,不會執行監聽函數,隻有值發生改變時才會執行。如果我們需要在最初綁定值的時候也執行函數,則就需要用到immediate屬性。
watch: {
docData: {
handler(newVal) {
this.change_number++
},
immediate: true
}
}
(2)deep
當需要監聽一個對象的改變時,普通的watch方法無法監聽到對象内部屬性的改變,此時就需要deep屬性對對象進行深度監聽。
data() {
return {
docData: {
'doc_id': 1,
'tpl_data': 'abc'
}
}
},
watch: {
docData: {
handler(newVal) {
this.change_number++
},
deep: true
}
}
設定deep:true則可以監聽到docData.doc_id的變化,此時會給docData的所有屬性都加上這個監聽器,當對象屬性較多時,每個屬性值的變化都會執行handler。如果隻需要監聽對象中的一個屬性值,則可以做以下優化:使用字元串的形式監聽對象屬性:
data() {
return {
docData: {
'doc_id': 1,
'tpl_data': 'abc'
}
}
},
watch: {
'docData.doc_id': {
handler(newVal, oldVal) {
......
},
deep: true
}
}
3、總結
數組(一維、多元)的變化不需要通過深度監聽,對象數組中對象的屬性變化則需要deep深度監聽。