您现在的位置是:网站首页> 编程资料编程资料
vue对象添加属性(key:value)、显示和删除属性方式_vue.js_
2023-05-24
386人已围观
简介 vue对象添加属性(key:value)、显示和删除属性方式_vue.js_
对象添加属性(key:value)、显示和删除属性
效果图

key值 value值 操作 {{key}} {{keyValues[key]}}
添加属性
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"})以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章:
相关内容
- JavaScript中关于递归与回溯的实例详解_javascript技巧_
- vue项目配置element-ui容易遇到的坑及解决_vue.js_
- 如何在vue中使用jsx语法_vue.js_
- Vue.extend实现组件库message组件示例详解_vue.js_
- uniapp使用H5调试时跨域问题解决_javascript技巧_
- Vue transx组件切换动画库示例详解_vue.js_
- nvm版本导致npm install报错Unexpected token '.'的解决办法_node.js_
- react-redux action传参及多个state处理的实现_React_
- vue实现过渡动画Message消息提示组件示例详解_vue.js_
- 关于vuex状态刷新网页时数据被清空问题及解决_vue.js_
