vue对象添加属性(key:value)、显示和删除属性方式

发布时间:2022-7-28 09:26

这篇文章主要介绍了vue对象添加属性(key:value)、显示和删除属性方式,具有很好的参考价值,希望对大家有所帮助。

对象添加属性(key:value)、显示和删除属性

效果图

<FormItem label="输入项填充内容 :" 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="输入内容" v-model="keyValue.key"></Input>
  </FormItem>
</td>
<td colspan="2">
  <FormItem>
<Input class="application-ipt" type="text" placeholder="输入内容" v-model="keyValue.value"></Input>
  </FormItem>
</td>
  </tr>
</table>
  </FormItem>

添加属性

 addKey(){
if(this.keyValue.key==''){
  this.$Message.error('请输入key值');
}else if(this.keyValue.value==''){
  this.$Message.error('请输入value值');
}else{
  if(JSON.stringify(this.keyValues) !== '{}'){
for(var k in this.keyValues){
  if(k == this.keyValue.key) {
this.$Message.error('key值不能重复');
this.keyValue.key=''
return
  }else{
this.keyValues[this.keyValue.key]=this.keyValue.value
this.keyValue.key=''
this.keyValue.value=''
//可以强制重新渲染页面
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();
  }
},

不能检测到对象属性的添加或删除问题

官网介绍到:受现代 JavaScript 的限制 (以及废弃 Object.observe),Vue 不能检测到对象属性的添加或删除。

由于 Vue 会在初始化实例时对属性执行 getter/setter 转化过程,所以属性必须在 data 对象上存在才能让 Vue 转换它,这样才能让它是响应的。

上面的a是响应式的,所以a的改变后会自动渲染页面;

但是b是在vm实例创建之后添加的属性,所以他不是响应式的,当我们改变b的值的时候,通过DevTool看到的数据并不会改变,除非我们在DevTool中刷新数据,而且页面也不会刷新。

有三种解决方案

方案一:利用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"})
Vue PostCSS的使用介绍 网站建设

Vue PostCSS的使用介绍

postcss 一种对css编译的工具,类似babel对js的处理,常见的功能如: 1 . 使用下一代css语法 2 . 自动补全浏览器前缀 3 . 自动把px代为转换成rem ...
Vue package.json配置深入分析 网站建设

Vue package.json配置深入分析

package.json是每个前端项目都会有的json文件,位于项目的根目录中。很多脚手架在创建项目的时候会帮我们自动初始化好 package.json。package.json有许多配置与项目息息相...