如何给Vue对象动态添加属性并展示、删除属性操作?

2026-03-31 17:231阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计835个文字,预计阅读时间需要4分钟。

如何给Vue对象动态添加属性并展示、删除属性操作?

目录+对象添加属性(key:value)、显示和删除属性+效果图+添加属性+删除属性+不能检测到对象属性的添加或删除问题+三种解决方案+对象添加属性(key:value)、显示和删除属性+效果图+表单I

目录
  • 对象添加属性(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对象动态添加属性并展示、删除属性操作?

本文共计835个文字,预计阅读时间需要4分钟。

如何给Vue对象动态添加属性并展示、删除属性操作?

目录+对象添加属性(key:value)、显示和删除属性+效果图+添加属性+删除属性+不能检测到对象属性的添加或删除问题+三种解决方案+对象添加属性(key:value)、显示和删除属性+效果图+表单I

目录
  • 对象添加属性(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对象动态添加属性并展示、删除属性操作?