vue 对象添加或删除成员时无法实时更新的解决方
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了vue 对象添加或删除成员时无法实时更新的解决方法,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
前阵子将项目搬上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'); //起作用 } },
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程