詳解vue.js中$set與數組如何更新

來源:互聯網
上載者:User
由於 JavaScript 的限制,Vue 不能檢測以下變動的數組:當利用索引直接設定數組的某一項時,例如:vm.items[indexOfItem] = newValue

當你修改數組的長度時,例如:vm.items.length = newLength,不會更新數組。

當然vue中給瞭解決方法,就是使用 Vue.set, vm.$set(Vue.set的變種寫法)或者 splice,caoncat等修改數組,同時也將觸發狀態更新:

ex:

所以如果在執行個體建立後添加新的屬性到執行個體上,則不會觸發更新。

ps:現在有兩個數組,分別為arr1,arr2,如果arr1以下標賦值改變數組,arr2以$set改變數組,結果是什麼樣呢?

data:{ arr1 = ['a','b','c']; arr2 = [‘foo','bar','baz'];  }vm.arr1[1] = 'alpha';vm.$set(vm.arr2, 1, 'alpha');

根據開始我們說的根據下標索引改變數組不能觸發狀態更新,我們會知道:第一個數組的第二項改變不會在頁面更新,只有第二個數組的更改會在頁面更新。然而結果卻是:

arr1 = ['a', 'alpha', 'b', 'c'];arr2 = [‘foo', 'alpha', 'bar','baz'];

兩個數組的值都更新了,也就是說,arr2用$set()方法更新時,頁面會全部更新一遍。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.