首页 > 编程 > JavaScript > 正文

vue 对象添加或删除成员时无法实时更新的解决方法

2019-11-19 11:39:40
字体:
来源:转载
供稿:网友

前阵子将项目搬上Vue的时候偶遇一个突发问题

当对象添加或删除成员时页面无法实时更新渲染,但是数组是正常的

目测是ob没有监听到对象的成员有变化

查看一些大家的求助回答是说ob监听的是数组length的变动 对象默认没有length 新增成员时不会自增length

所以监听不到对象的变化 最近大脑过于疲惫 懒得看文档了。。。

不多废话 解决方式直接上代码

在实例内部可以用$set和$delete

this.$set(this.age,'age',18);this.$delete(this.age,'age');

也可以直接调用Vue的set和delete

let vm = new Vue({  el : '#app',  data : {    age:{}  }});Vue.set(vm.age,'age',18);Vue.delete(vm.age,'age');

PS:vue给数组和对象进行增加删除字段不更新数据的解决方法 ― Vue.set(object, key, value)

组件基本代码:

<style lang="sass"></style><template><div>  <div>    <div>    </div>  </div></div></template><script>  export default {    data(){      return {      }    },    methods: {      ceshi(){      }    }  }</script>

1.数组的增加,删除(数组的push等方法排除)

</style><template><div>  <div>    <div>      <div v-for="item in items">        <span>{{ item }}</span>      </div>      <button @click="ceshi">anniu</button>    </div>  </div></div></template><script>  export default {    data(){      return {        items: [11,22],        obj: { a: 'aa', b: 'bb' }      }    },    methods: {      ceshi(){        this.items[2] = 33; // 这样的写法数据是无法重新渲染的      }    }  }</script>

点击按钮操作ceshi事件前后,没发生变化

解决方法:

就是利用数据的push方法是可以实现的

利用Vue.set方法

具体实现如下:

methods: {  ceshi(){    this.$set(this.items, 2, 33)  }},

同理,如果items: [{a: ‘11'}] > items: [{a: ‘11', b: ‘22'}]

<div v-for="item in items"> <span v-for="(i, j) in item">{{ i }}--{{ j }}</span></div>this.items[0] = Object.assign({}, this.items[0], { b: '22' });this.$set(this.items, 0, this.items[0]);

2.给对象增加新属性(同理)

<template>  <div>    <div v-for="item in obj">     <span>{{ item }}</span>    </div>  </div></template>data(){  return {    obj: { a: 'aa', b: 'bb' }  }}methods: {  ceshi(){    this.obj['c'] = '000'; // 不起作用    this.$set(this.obj, 'c', '000'); //起作用   }},

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表