亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳解Vue中watch對象內屬性的方法

發布時間:2020-10-14 21:10:11 來源:腳本之家 閱讀:124 作者:OceanZH 欄目:web開發

vue提供了watch方法,用于監聽實例內data數據的變化。通常寫法是:

new Vue({
 data: {
  count: 10,
  blog:{
    title:'my-blog',
    categories:[]
  }
 },
 watch: {
  count: function (newval, oldVal) {
   console.log(`new: %s, old: %s`, newVal, oldVal);
  }
 }
})

上述情況里data中的count屬性可以直接監聽,但是如果需要監聽的數據是對象內的某一屬性值的變化,直接watch對象blog是檢測不到變化的,這是因為blog這個對象的指向并沒有發生改變。有幾個解決方法

1.深度監測

new Vue({
 data: {
  count: 10,
  blog:{
    title:'my-blog',
    categories:[]
  }
 },
 watch: {
  blog:{
    handler(newVal,oldVal){
      console.log(`new: ${newVal}, old: ${oldVal}`);
    },
    deep:true
  }
 }
})

里面的deep設為了true,這樣的話,如果修改了這個blog中的任何一個屬性,都會執行handler這個方法。不過這樣會造成更多的性能開銷,尤其是對象里面屬性過多,結構嵌套過深的時候。而且有時候我們就只想關心這個對象中的某個特定屬性,這個時候可以這樣

2.用字符串來表示對象的屬性調用

new Vue({
 data: {
  count: 10,
  blog:{
    title:'my-blog',
    categories:[]
  }
 },
 watch: {
  'blog.categories'(newVal, oldVal) {
    console.log(`new:${newVal}, old:${oldVal}`);
  }, 
 }
})

3.使用computed計算屬性

new Vue({
 data: {
  count: 10,
  blog:{
    title:'my-blog',
    categories:[]
  }
 },
 computed: {
  categories() {
   return this.blog.categories;
  }
 },
 watch: {
  categories(newVal, oldVal) {
   console.log(`new:${newVal}, old:${oldVal}`);
  }, 
 },
})

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

开江县| 博兴县| 晋州市| 临江市| 金门县| 肇州县| 沙田区| 上虞市| 瑞丽市| 嘉祥县| 新晃| 甘南县| 衡阳县| 呼图壁县| 大埔县| 定襄县| 三门峡市| 遂昌县| 剑川县| 高邑县| 黑山县| 桦川县| 宁国市| 宝应县| 博乐市| 海伦市| 漠河县| 乌海市| 荣昌县| 佛冈县| 孝昌县| 建德市| 曲麻莱县| 调兵山市| 博野县| 马山县| 新乐市| 阳西县| 庆城县| 郑州市| 双桥区|