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


Posted in Javascript onMay 01, 2019

前阵子将项目搬上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事件前后,没发生变化

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

解决方法:

就是利用数据的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'); //起作用 
  }
},

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript笔记一 js以及json基础使用说明
May 22 Javascript
对象无length属性时IE6/IE7中无法将其转换成伪数组(ArrayLike)
Jul 31 Javascript
javascript跟随滚动效果插件代码(javascript Follow Plugin)
Aug 03 Javascript
javascript中全局对象的parseInt()方法使用介绍
Dec 19 Javascript
怎么通过onclick事件获取js函数返回值(代码少)
Jul 28 Javascript
jQuery四种选择器使用及示例
Jun 05 Javascript
前端开发之CSS原理详解
Mar 11 Javascript
深究AngularJS之ui-router详解
Jun 13 Javascript
Javascript获取某个月的天数
May 30 Javascript
JQuery事件委托原理与用法实例分析
May 13 jQuery
js 实现 list转换成tree的方法示例(数组到树)
Aug 18 Javascript
antd-日历组件,前后禁止选择,只能选中间一部分的实例
Oct 29 Javascript
JavaScript强制类型转换和隐式类型转换操作示例
May 01 #Javascript
Vue源码之关于vm.$delete()/Vue.use()内部原理详解
May 01 #Javascript
Vue.extend实现挂载到实例上的方法
May 01 #Javascript
JS html事件冒泡和事件捕获操作示例
May 01 #Javascript
JS实现的贪吃蛇游戏案例详解
May 01 #Javascript
javascript原型链学习记录之继承实现方式分析
May 01 #Javascript
微信小程序实现卡片左右滑动效果的示例代码
May 01 #Javascript
You might like
浅析SVN常见问题及解决方法
2013/06/21 PHP
解读PHP中上传文件的处理问题
2016/05/29 PHP
javascript编程起步(第七课)
2007/01/10 Javascript
fckeditor 获取文本框值的实现代码
2009/02/09 Javascript
JS 日期验证正则附asp日期格式化函数
2009/09/11 Javascript
ASP小贴士/ASP Tips javascript tips可以当桌面
2009/12/10 Javascript
innerHTML与jquery里的html()区别介绍
2012/10/12 Javascript
如何使用Javascript获取距今n天前的日期
2013/07/08 Javascript
ExtJS4 动态生成的grid导出为excel示例
2014/05/02 Javascript
JavaScript实现生成GUID(全局统一标识符)
2014/09/05 Javascript
JavaScript实现获取dom中class的方法
2015/02/09 Javascript
AngularJs解决跨域问题案例详解(简单方法)
2016/05/19 Javascript
JS匿名函数实例分析
2016/11/26 Javascript
smartupload实现文件上传时获取表单数据(推荐)
2016/12/12 Javascript
JS作用域链详解
2017/06/26 Javascript
微信小程序slider组件使用详解
2018/01/31 Javascript
简化vuex的状态管理方案的方法
2018/06/02 Javascript
layui: layer.open加载窗体时出现遮罩层的解决方法
2019/09/26 Javascript
vuex + keep-alive实现tab标签页面缓存功能
2019/10/17 Javascript
Python实现求最大公约数及判断素数的方法
2015/05/26 Python
python操作ssh实现服务器日志下载的方法
2015/06/03 Python
5款非常棒的Python工具
2018/01/05 Python
Python(TensorFlow框架)实现手写数字识别系统的方法
2018/05/29 Python
python递归实现快速排序
2018/08/18 Python
Django 开发环境与生产环境的区分详解
2019/07/26 Python
在python中创建指定大小的多维数组方式
2019/11/28 Python
tensorflow 保存模型和取出中间权重例子
2020/01/24 Python
Django的CVB实例详解
2020/02/10 Python
Python flask框架实现浏览器点击自定义跳转页面
2020/06/04 Python
装潢设计实习自我鉴定
2013/09/19 职场文书
父亲的菜园教学反思
2014/02/13 职场文书
小城镇建设汇报材料
2014/08/16 职场文书
优秀教师个人总结
2015/02/11 职场文书
2015年度女工工作总结
2015/10/22 职场文书
2016机关干部作风建设心得体会
2016/01/21 职场文书
小学教代会开幕词
2016/03/04 职场文书