vue.js中$set與數(shù)組更新方法
由于 JavaScript 的限制,Vue 不能檢測以下變動(dòng)的數(shù)組:
當(dāng)利用索引直接設(shè)置數(shù)組的某一項(xiàng)時(shí),例如:vm.items[indexOfItem] = newValue
當(dāng)你修改數(shù)組的長度時(shí),例如:vm.items.length = newLength,不會(huì)更新數(shù)組。
當(dāng)然vue中給了解決方法,就是使用 Vue.set, vm.$set(Vue.set的變種寫法)或者 splice,caoncat等修改數(shù)組,同時(shí)也將觸發(fā)狀態(tài)更新:
ex:
所以如果在實(shí)例創(chuàng)建后添加新的屬性到實(shí)例上,則不會(huì)觸發(fā)更新。
ps:現(xiàn)在有兩個(gè)數(shù)組,分別為arr1,arr2,如果arr1以下標(biāo)賦值改變數(shù)組,arr2以$set改變數(shù)組,結(jié)果是什么樣呢?
data:{ arr1 = ['a','b','c']; arr2 = [‘foo','bar','baz']; } vm.arr1[1] = 'alpha'; vm.$set(vm.arr2, 1, 'alpha');
根據(jù)開始我們說的根據(jù)下標(biāo)索引改變數(shù)組不能觸發(fā)狀態(tài)更新,我們會(huì)知道:第一個(gè)數(shù)組的第二項(xiàng)改變不會(huì)在頁面更新,只有第二個(gè)數(shù)組的更改會(huì)在頁面更新。然而結(jié)果卻是:
arr1 = ['a', 'alpha', 'b', 'c']; arr2 = [‘foo', 'alpha', 'bar','baz'];
兩個(gè)數(shù)組的值都更新了,也就是說,arr2用$set()方法更新時(shí),頁面會(huì)全部更新一遍。
以上這篇vue.js中$set與數(shù)組更新方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue input輸入框關(guān)鍵字篩選檢索列表數(shù)據(jù)展示
這篇文章主要為大家詳細(xì)介紹了vue input輸入框關(guān)鍵字篩選檢索列表數(shù)據(jù)展示,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05vue開發(fā)runtime core中的虛擬節(jié)點(diǎn)示例詳解
這篇文章主要為大家介紹了vue開發(fā)runtime core中的虛擬節(jié)點(diǎn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11在vue-cli 3中給stylus、sass樣式傳入共享的全局變量
這篇文章主要介紹了在vue-cli 3中, 給stylus、sass樣式傳入共享的全局變量,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08