解决vue数组中对象属性变化页面不渲染问题


Posted in Javascript onAugust 09, 2018

做checkbox多选功能的时候遇到了一个坑,逻辑怎么看都对,但是就是有bug,最后发现数组那里值变了页面勾选没有重新渲染。

换了关键词搜索找到了相关方法。

其实之前读文档教程的时候看到过这里,但是只有真的使用之后才会有最直接的感触。

数组更新检测

变异方法

Vue 包含一组观察数组的变异方法,所以它们也将会触发视图更新。这些方法如下:

push()
pop()
shift()
unshift()
splice()
sort()
reverse()

你打开控制台,然后用前面例子的 items 数组调用变异方法:example1.items.push({ message: 'Baz' }) 。

替换数组

变异方法 (mutation method),顾名思义,会改变被这些方法调用的原始数组。相比之下,也有非变异 (non-mutating method) 方法,例如:filter(), concat() 和 slice() 。这些不会改变原始数组,但总是返回一个新数组。当使用非变异方法时,可以用新数组替换旧数组:

example1.items = example1.items.filter(function (item) {
return item.message.match(/Foo/)
})

你可能认为这将导致 Vue 丢弃现有 DOM 并重新渲染整个列表。幸运的是,事实并非如此。Vue 为了使得 DOM 元素得到最大范围的重用而实现了一些智能的、启发式的方法,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作。

注意事项

由于 JavaScript 的限制,Vue 不能检测以下变动的数组:

当你利用索引直接设置一个项时,例如:vm.items[indexOfItem] = newValue

当你修改数组的长度时,例如:vm.items.length = newLength

为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将触发状态更新:

// Vue.set
Vue.set(example1.items, indexOfItem, newValue)
// Array.prototype.splice
example1.items.splice(indexOfItem, 1, newValue)

为了解决第二类问题,你可以使用 splice:

example1.items.splice(newLength)

对象更改检测注意事项

还是由于 JavaScript 的限制,Vue 不能检测对象属性的添加或删除:

var vm = new Vue({
data: {
a: 1
}
})
// `vm.a` 现在是响应式的
 
vm.b = 2
// `vm.b` 不是响应式的

对于已经创建的实例,Vue 不能动态添加根级别的响应式属性。但是,可以使用 Vue.set(object, key, value) 方法向嵌套对象添加响应式属性。例如,对于:

var vm = new Vue({
data: {
userProfile: {
name: 'Anika'
}
}
})

你可以添加一个新的 age 属性到嵌套的 userProfile 对象:

Vue.set(vm.userProfile, 'age', 27)

你还可以使用 vm.$set 实例方法,它只是全局 Vue.set 的别名:

this.$set(this.userProfile, 'age', 27)

有时你可能需要为已有对象赋予多个新属性,比如使用 Object.assign() 或 _.extend()。在这种情况下,你应该用两个对象的属性创建一个新的对象。所以,如果你想添加新的响应式属性,不要像这样:

Object.assign(this.userProfile, {
age: 27,
favoriteColor: 'Vue Green'
})

你应该这样做:

this.userProfile = Object.assign({}, this.userProfile, {
age: 27,
favoriteColor: 'Vue Green'
})

以上这篇解决vue数组中对象属性变化页面不渲染问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Android中资源文件(非代码部分)的使用概览
Dec 18 Javascript
jQuery 淡入淡出 png图在ie8下有黑色边框的解决方法
Mar 05 Javascript
js中小数转换整数的方法
Jan 26 Javascript
使用jQuery和PHP实现类似360功能开关效果
Feb 12 Javascript
js解析json读取List中的实体对象示例
Mar 11 Javascript
封装好的一个万能检测表单的方法
Jan 21 Javascript
jQuery实现表格展开与折叠的方法
May 04 Javascript
javascript实现图片左右滚动效果【可自动滚动,有左右按钮】
Sep 19 Javascript
jQuery插件MovingBoxes实现左右滑动中间放大图片效果
Feb 28 Javascript
Node.js操作redis实现添加查询功能
May 25 Javascript
详解Node项目部署到云服务器上
Jul 12 Javascript
详解axios 全攻略之基本介绍与使用(GET 与 POST)
Sep 15 Javascript
JavaScript引用类型Function实例详解
Aug 09 #Javascript
jquery ajax加载数据前台渲染方式 不用for遍历的方法
Aug 09 #jQuery
JavaScript引用类型之基本包装类型实例分析【Boolean、Number和String】
Aug 09 #Javascript
vue修改对象的属性值后页面不重新渲染的实例
Aug 09 #Javascript
vue异步axios获取的数据渲染到页面的方法
Aug 09 #Javascript
vue2.0的虚拟DOM渲染思路分析
Aug 09 #Javascript
Angular动画实现的2种方式以及添加购物车动画实例代码
Aug 09 #Javascript
You might like
PHP学习笔记 IIS7下安装配置php环境
2012/10/29 PHP
PHP实现的文件上传类与用法详解
2017/07/05 PHP
Jquery EasyUI的添加,修改,删除,查询等基本操作介绍
2013/10/11 Javascript
简单方法判断JavaScript对象为null或者属性为空
2014/09/26 Javascript
JavaScript中的函数(二)
2015/12/23 Javascript
谈一谈JS消息机制和事件机制的理解
2016/04/14 Javascript
JS产生随机数的几个用法详解
2016/06/22 Javascript
使用bootstrap typeahead插件实现输入框自动补全之问题及解决办法
2016/07/07 Javascript
关于AngularJs数据的本地存储详解
2017/01/20 Javascript
jquery代码规范让代码越来越好看
2017/02/03 Javascript
基于JavaScript实现的顺序查找算法示例
2017/04/14 Javascript
详解从新建vue项目到引入组件Element的方法
2017/08/29 Javascript
AngularJS的$location使用方法详解
2017/10/19 Javascript
结合mint-ui移动端下拉加载实践方法总结
2017/11/08 Javascript
js中Array对象的常用遍历方法详解
2019/01/17 Javascript
如何在Vue.JS中使用图标组件
2020/08/04 Javascript
[30:00]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第二场 11.28
2020/12/01 DOTA
[49:11]完美世界DOTA2联赛PWL S3 INK ICE vs DLG 第二场 12.20
2020/12/23 DOTA
python实现调用其他python脚本的方法
2014/10/05 Python
Python中time模块与datetime模块在使用中的不同之处
2015/11/24 Python
Python中内置数据类型list,tuple,dict,set的区别和用法
2015/12/14 Python
Python使用asyncio包处理并发详解
2017/09/09 Python
Python字典操作详细介绍及字典内建方法分享
2018/01/04 Python
Python3 XML 获取雅虎天气的实现方法
2018/02/01 Python
浅谈django2.0 ForeignKey参数的变化
2019/08/06 Python
django项目用higcharts统计最近七天文章点击量
2019/08/17 Python
WxPython实现无边框界面
2019/11/18 Python
tensorflow 限制显存大小的实现
2020/02/03 Python
十佳护士获奖感言
2014/02/18 职场文书
元旦趣味活动方案
2014/08/22 职场文书
2014年乡镇党建工作总结
2014/11/11 职场文书
汽车质检员岗位职责
2015/04/08 职场文书
匿名信格式范文
2015/05/27 职场文书
导游经典开场白——导游词
2019/04/17 职场文书
Django Paginator分页器的使用示例
2021/06/23 Python
Java 死锁解决方案
2022/05/11 Java/Android