vue對象或者數(shù)組中數(shù)據(jù)變化但是視圖沒有更新問題及解決
vue對象或數(shù)組中數(shù)據(jù)變化但視圖沒更新
由于 JavaScript 的限制,Vue 不能檢測數(shù)組和對象的變化。
但是我們還是有一些辦法來回避這些限制并保證它們的響應(yīng)性。
一、對于對象
**Vue 無法檢測 property 的添加或移除。
由于 Vue 會在初始化實(shí)例時(shí)對 property 執(zhí)行 getter/setter 轉(zhuǎn)化,所以 property 必須在 data
對象上存在才能讓 Vue 將它轉(zhuǎn)換為響應(yīng)式的。
例如:
var vm = new Vue({ data:{ a:1 } }) // `vm.a` 是響應(yīng)式的 vm.b = 2 // `vm.b` 是非響應(yīng)式的
對于已經(jīng)創(chuàng)建的實(shí)例,Vue 不允許動態(tài)添加根級別的響應(yīng)式 property。
但是,可以使用 Vue.set(object, propertyName, value)
方法向嵌套對象添加響應(yīng)式 property。
例如,對于:
Vue.set(vm.someObject, 'b', 2)
您還可以使用 vm.$set 實(shí)例方法,這也是全局 Vue.set 方法的別名:
this.$set(this.someObject,'b',2)
有時(shí)你可能需要為已有對象賦值多個新 property,比如使用 Object.assign()
或 _.extend()
。
但是,這樣添加到對象上的新 property 不會觸發(fā)更新。
在這種情況下,你應(yīng)該用原對象與要混合進(jìn)去的對象的 property 一起創(chuàng)建一個新的對象。
// 代替 `Object.assign(this.someObject, { a: 1, b: 2 })` this.someObject = Object.assign({}, this.someObject, { a: 1, b: 2 })
二、對于數(shù)組
Vue 不能檢測以下數(shù)組的變動:
- 當(dāng)你利用索引直接設(shè)置一個數(shù)組項(xiàng)時(shí),例如:
vm.items[indexOfItem] = newValue
- 當(dāng)你修改數(shù)組的長度時(shí),例如:
vm.items.length = newLength
舉個例子:
var vm = new Vue({ data: { items: ['a', 'b', 'c'] } }) vm.items[1] = 'x' // 不是響應(yīng)性的 vm.items.length = 2 // 不是響應(yīng)性的
為了解決第一類問題,以下兩種方式都可以實(shí)現(xiàn)和 vm.items[indexOfItem] = newValue
相同的效果,同時(shí)也將在響應(yīng)式系統(tǒng)內(nèi)觸發(fā)狀態(tài)更新:
// Vue.set Vue.set(vm.items, indexOfItem, newValue)
// Array.prototype.splice vm.items.splice(indexOfItem, 1, newValue)
你也可以使用 vm.$set 實(shí)例方法,該方法是全局方法 Vue.set
的一個別名:
vm.$set(vm.items, indexOfItem, newValue)
為了解決第二類問題,你可以使用 splice
:
vm.items.splice(newLength)
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue render函數(shù)實(shí)戰(zhàn)之實(shí)現(xiàn)tabs選項(xiàng)卡組件
這篇文章主要介紹了Vue render函數(shù)實(shí)戰(zhàn)之實(shí)現(xiàn)tabs選項(xiàng)卡組件的相關(guān)知識,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04vue Treeselect 樹形下拉框:獲取選中節(jié)點(diǎn)的ids和lables操作
這篇文章主要介紹了vue Treeselect 樹形下拉框:獲取選中節(jié)點(diǎn)的ids和lables操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值實(shí)例詳解
父組件通過屬性傳值給子組件,父組件修改數(shù)據(jù)后會刷新頁面并重新傳值給子組件,子組件可以修改父組件傳的值并刷新自己的頁面?但是并不會修改父組件中的值,這篇文章主要介紹了vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值,需要的朋友可以參考下2022-09-09vue實(shí)現(xiàn)進(jìn)入全屏和退出全屏的示例代碼
最近一個項(xiàng)目需要進(jìn)行大屏展示,所以登錄完就要處于一個全屏的狀態(tài),本文主要介紹了vue實(shí)現(xiàn)進(jìn)入全屏和退出全屏的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12Vue表單數(shù)據(jù)修改與刪除功能實(shí)現(xiàn)
本文通過實(shí)例代碼介紹了Vue表單數(shù)據(jù)修改與刪除功能實(shí)現(xiàn),結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友跟隨小編一起看看吧2023-10-10