1. 程式人生 > >vue中的watch監聽資料變化以及watch中各屬性詳解

vue中的watch監聽資料變化以及watch中各屬性詳解

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屬性。eg:

watch: {
    docData: {
        handler(newVal) {
            this.change_number++
        },
        immediate: true
    }
}    

(2)deep當需要監聽一個物件的改變時,普通的watch方法無法監聽到物件內部屬性的改變,此時就需要deep屬性對物件進行深度監聽。eg:

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:

data() {
    return {
        docData: {
            'doc_id': 1,
            'tpl_data': 'abc'
        }
    }
},
watch: {
    'docData.doc_id': {
        handler(newVal, oldVal) {
             ......
        },
    deep: true
    }    
}

這樣只會給物件的某個特定的屬性加監聽器

3、總結陣列(一維、多維)的變化不需要通過深度監聽,物件陣列中物件的屬性變化則需要deep深度監聽。