温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

vue对象添加属性、显示和删除属性是什么

发布时间:2022-07-28 09:42:29 来源:亿速云 阅读:214 作者:iii 栏目:开发技术

这篇文章主要讲解了“vue对象添加属性、显示和删除属性是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue对象添加属性、显示和删除属性是什么”吧!

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

效果图

vue对象添加属性、显示和删除属性是什么

<FormItem label="输入项填充内容 :" prop="value" :rules="name1" >
            <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 转换它,这样才能让它是响应的。

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对象添加属性、显示和删除属性是什么”的内容了,经过本文的学习后,相信大家对vue对象添加属性、显示和删除属性是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI