vue對(duì)象添加屬性(key:value)、顯示和刪除屬性方式
對(duì)象添加屬性(key:value)、顯示和刪除屬性
效果圖

<FormItem label="輸入項(xiàng)填充內(nèi)容 :" prop="value" :rules="name1" style="margin-top: 20px">
<Button type="success" @click="addKey">新增</Button>
<table class="table">
<tr>
<th>key值</th>
<th>value值</th>
<th>操作</th>
</tr>
<tr v-for="(item,key) in keyValues" v-if="keyValueShow">
<td>{{key}}</td>
<td>{{keyValues[key]}}</td>
<td><Button type="error" @click="keyDelete(key)">刪除</Button></td>
</tr>
<tr>
<td>
<FormItem>
<Input class="application-ipt" type="text" placeholder="輸入內(nèi)容" v-model="keyValue.key"></Input>
</FormItem>
</td>
<td colspan="2">
<FormItem>
<Input class="application-ipt" type="text" placeholder="輸入內(nèi)容" v-model="keyValue.value"></Input>
</FormItem>
</td>
</tr>
</table>
</FormItem>添加屬性
addKey(){
if(this.keyValue.key==''){
this.$Message.error('請(qǐng)輸入key值');
}else if(this.keyValue.value==''){
this.$Message.error('請(qǐng)輸入value值');
}else{
if(JSON.stringify(this.keyValues) !== '{}'){
for(var k in this.keyValues){
if(k == this.keyValue.key) {
this.$Message.error('key值不能重復(fù)');
this.keyValue.key=''
return
}else{
this.keyValues[this.keyValue.key]=this.keyValue.value
this.keyValue.key=''
this.keyValue.value=''
//可以強(qiáng)制重新渲染頁(yè)面
this.$forceUpdate();
}
}
}else{
this.keyValues[this.keyValue.key]=this.keyValue.value
this.keyValue.key=''
this.keyValue.value=''
this.$forceUpdate();
}
}
},刪除屬性
keyDelete(key){
var keyValues = this.keyValues
for (var k in keyValues) {
console.log(k,key)
if(k==key){
delete keyValues[k]
}
this.keyValues=keyValues
this.$forceUpdate();
}
},不能檢測(cè)到對(duì)象屬性的添加或刪除問(wèn)題
官網(wǎng)介紹到:受現(xiàn)代 JavaScript 的限制 (以及廢棄 Object.observe),Vue 不能檢測(cè)到對(duì)象屬性的添加或刪除。
由于 Vue 會(huì)在初始化實(shí)例時(shí)對(duì)屬性執(zhí)行 getter/setter 轉(zhuǎn)化過(guò)程,所以屬性必須在 data 對(duì)象上存在才能讓 Vue 轉(zhuǎn)換它,這樣才能讓它是響應(yīng)的。

上面的a是響應(yīng)式的,所以a的改變后會(huì)自動(dòng)渲染頁(yè)面;
但是b是在vm實(shí)例創(chuàng)建之后添加的屬性,所以他不是響應(yīng)式的,當(dāng)我們改變b的值的時(shí)候,通過(guò)DevTool看到的數(shù)據(jù)并不會(huì)改變,除非我們?cè)贒evTool中刷新數(shù)據(jù),而且頁(yè)面也不會(huì)刷新。
有三種解決方案
- 方案一:利用Vue.set(object,key,value)
Vue.set(vm.obj,"sex","man")
- 方案二:利用this.$set(this.object,key,value)
this.$set(this.obj,"sex","man")
- 方案三:利用Object.assign({},this.obj)
this.obj.sex = "man";this.obj = Object.assign({},this.obj)- 或者下面方式
this.obj = Object.assign({ },this.obj,{"sex","man"})以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue框架和react框架的區(qū)別以及各自的應(yīng)用場(chǎng)景使用
這篇文章主要介紹了vue框架和react框架的區(qū)別以及各自的應(yīng)用場(chǎng)景使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
vue的url請(qǐng)求圖片的問(wèn)題及請(qǐng)求失敗解決
這篇文章主要介紹了vue的url請(qǐng)求圖片的問(wèn)題及請(qǐng)求失敗解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Vuex模塊化實(shí)現(xiàn)待辦事項(xiàng)的狀態(tài)管理
本文主要介紹了Vuex模塊化實(shí)現(xiàn)待辦事項(xiàng)的狀態(tài)管理的相關(guān)知識(shí),具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-03-03
基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo
這篇文章主要介紹了基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
理解Proxy及使用Proxy實(shí)現(xiàn)vue數(shù)據(jù)雙向綁定操作
這篇文章主要介紹了理解Proxy及使用Proxy實(shí)現(xiàn)vue數(shù)據(jù)雙向綁定操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
vue中的echarts實(shí)現(xiàn)寬度自適應(yīng)的解決方案
這篇文章主要介紹了vue中的echarts實(shí)現(xiàn)寬度自適應(yīng),本文給大家分享實(shí)現(xiàn)方案,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09
vue動(dòng)態(tài)路由實(shí)現(xiàn)多級(jí)嵌套面包屑的思路與方法
在實(shí)際項(xiàng)目中我們會(huì)碰到多層嵌套的組件組合而成,比如我們常見(jiàn)的面包屑導(dǎo)航,下面這篇文章就來(lái)給大家介紹關(guān)于vue實(shí)現(xiàn)動(dòng)態(tài)路由多級(jí)嵌套面包屑的思路與方法,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-08-08
vue keep-alive的簡(jiǎn)單總結(jié)
這篇文章主要介紹了vue中的keep-alive的相關(guān)資料,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2021-01-01

