vue 對(duì)象添加或刪除成員時(shí)無法實(shí)時(shí)更新的解決方法
前陣子將項(xiàng)目搬上Vue的時(shí)候偶遇一個(gè)突發(fā)問題
當(dāng)對(duì)象添加或刪除成員時(shí)頁(yè)面無法實(shí)時(shí)更新渲染,但是數(shù)組是正常的
目測(cè)是ob沒有監(jiān)聽到對(duì)象的成員有變化
查看一些大家的求助回答是說ob監(jiān)聽的是數(shù)組length的變動(dòng) 對(duì)象默認(rèn)沒有l(wèi)ength 新增成員時(shí)不會(huì)自增length
所以監(jiān)聽不到對(duì)象的變化 最近大腦過于疲憊 懶得看文檔了。。。
不多廢話 解決方式直接上代碼
在實(shí)例內(nèi)部可以用$set和$delete
this.$set(this.age,'age',18); this.$delete(this.age,'age');
也可以直接調(diào)用Vue的set和delete
let vm = new Vue({ el : '#app', data : { age:{} } }); Vue.set(vm.age,'age',18); Vue.delete(vm.age,'age');
PS:vue給數(shù)組和對(duì)象進(jìn)行增加刪除字段不更新數(shù)據(jù)的解決方法 — Vue.set(object, key, value)
組件基本代碼:
<style lang="sass"> </style> <template> <div> <div> <div> </div> </div> </div> </template> <script> export default { data(){ return { } }, methods: { ceshi(){ } } } </script>
1.數(shù)組的增加,刪除(數(shù)組的push等方法排除)
</style> <template> <div> <div> <div> <div v-for="item in items"> <span>{{ item }}</span> </div> <button @click="ceshi">anniu</button> </div> </div> </div> </template> <script> export default { data(){ return { items: [11,22], obj: { a: 'aa', b: 'bb' } } }, methods: { ceshi(){ this.items[2] = 33; // 這樣的寫法數(shù)據(jù)是無法重新渲染的 } } } </script>
點(diǎn)擊按鈕操作ceshi事件前后,沒發(fā)生變化
解決方法:
就是利用數(shù)據(jù)的push方法是可以實(shí)現(xiàn)的
利用Vue.set方法
具體實(shí)現(xiàn)如下:
methods: { ceshi(){ this.$set(this.items, 2, 33) } },
同理,如果items: [{a: ‘11'}] –> items: [{a: ‘11', b: ‘22'}]
<div v-for="item in items"> <span v-for="(i, j) in item">{{ i }}--{{ j }}</span> </div> this.items[0] = Object.assign({}, this.items[0], { b: '22' }); this.$set(this.items, 0, this.items[0]);
2.給對(duì)象增加新屬性(同理)
<template> <div> <div v-for="item in obj"> <span>{{ item }}</span> </div> </div> </template> data(){ return { obj: { a: 'aa', b: 'bb' } } } methods: { ceshi(){ this.obj['c'] = '000'; // 不起作用 this.$set(this.obj, 'c', '000'); //起作用 } },
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue項(xiàng)目中v-bind動(dòng)態(tài)綁定src路徑不成功問題及解決
這篇文章主要介紹了Vue項(xiàng)目中v-bind動(dòng)態(tài)綁定src路徑不成功問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04vue中的dom節(jié)點(diǎn)和window對(duì)象
這篇文章主要介紹了vue中的dom節(jié)點(diǎn)和window對(duì)象,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04Vue實(shí)現(xiàn)雙token無感刷新的示例代碼
這篇文章主要介紹了Vue實(shí)現(xiàn)雙token無感刷新,雙token機(jī)制,尤其是指在OAuth 2.0授權(quán)協(xié)議中廣泛使用的access token(訪問令牌)和refresh token(刷新令牌)組合,文中通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-03-03vue使用socket與服務(wù)端進(jìn)行通信的代碼詳解
這篇文章主要給大家介紹了vue如何使用socket與服務(wù)端進(jìn)行通信的相關(guān)資料,在Vue中我們可以將Websocket類封裝成一個(gè)Vue插件,以便全局使用,需要的朋友可以參考下2023-09-09Vue函數(shù)式組件的應(yīng)用實(shí)例詳解
這篇文章主要介紹了Vue函數(shù)式組件的應(yīng)用實(shí)例詳解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08