一、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) } }
二、詳解watch中的immediate、handler和deep屬性
(1)immediate和handler
這樣使用watch時有一個特色,就是當值第一次綁定時,不會執行監聽函數,只有值發生改變時纔會執行。若是咱們須要在最初綁定值的時候也執行函數,則就須要用到immediate屬性。
eg:this
watch: { docData: { handler(newVal) { this.change_number++ }, immediate: true } }
(2)deep
當須要監聽一個對象的改變時,普通的watch方法沒法監聽到對象內部屬性的改變,此時就須要deep屬性對對象進行深度監聽。
eg:spa
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。若是隻須要監聽對象中的一個屬性值,則能夠作如下優化:使用字符串的形式監聽對象屬性:
eg:code
data() { return { docData: { 'doc_id': 1, 'tpl_data': 'abc' } } }, watch: { 'docData.doc_id': { handler(newVal, oldVal) { ...... }, deep: true } }
這樣只會給對象的某個特定的屬性加監聽器對象
三、總結
數組(一維、多維)的變化不須要經過深度監聽,對象數組中對象的屬性變化則須要deep深度監聽。blog