解决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 相关文章推荐
JavaScript数据类型学习笔记分享
Sep 01 Javascript
JavaScript简单下拉菜单特效
Sep 13 Javascript
js中获取键盘事件的简单实现方法
Oct 10 Javascript
JavaScript重定向URL参数的两种方法小结
Oct 19 Javascript
JavaScript中的await/async的作用和用法
Oct 31 Javascript
微信小程序 基础知识css样式media标签
Feb 15 Javascript
webstorm中vue语法的支持详解
May 09 Javascript
小程序数据通信方法大全(推荐)
Apr 15 Javascript
基于JS实现简单滑块拼图游戏
Oct 12 Javascript
mpvue实现小程序签到金币掉落动画(api实现)
Oct 17 Javascript
重置Redux的状态数据的方法实现
Nov 18 Javascript
小程序实现长按保存图片的方法
Dec 31 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.ini中文版(1)
2006/10/09 PHP
浅析is_writable的php实现
2013/06/18 PHP
php中静态类与静态变量用法的区别分析
2015/01/15 PHP
yii2 RBAC使用DbManager实现后台权限判断的方法
2016/07/23 PHP
php利用嵌套数组拼接与解析json的方法
2017/02/07 PHP
javascript事件问题
2009/09/05 Javascript
可自己添加html的伪弹出框实现代码
2013/09/08 Javascript
10条建议帮助你创建更好的jQuery插件
2015/05/18 Javascript
AngularJS 入门教程之事件处理器详解
2016/08/19 Javascript
Vue.js在数组中插入重复数据的实现代码
2017/11/17 Javascript
vue中动态设置meta标签和title标签的方法
2018/07/11 Javascript
vue实现学生录入系统之添加删除功能
2018/07/11 Javascript
一文了解Vue中的nextTick
2019/05/06 Javascript
JS浮点数运算结果不精确的Bug解决
2019/08/01 Javascript
微信小程序页面滚动到指定位置代码实例
2019/09/07 Javascript
JS数组reduce()方法原理及使用技巧解析
2020/07/14 Javascript
JSON 入门教程基础篇 json入门学习笔记
2020/09/22 Javascript
[38:38]完美世界DOTA2联赛PWL S3 access vs Rebirth 第二场 12.17
2020/12/18 DOTA
[01:11:46]DOTA2-DPC中国联赛 正赛 iG vs Magma BO3 第一场 2月23日
2021/03/11 DOTA
python3使用SMTP发送HTML格式邮件
2018/06/19 Python
对python for 文件指定行读写操作详解
2018/12/29 Python
pyhanlp安装介绍和简单应用
2019/02/22 Python
Python使用pandas和xlsxwriter读写xlsx文件的方法示例
2019/04/09 Python
pytorch 获取层权重,对特定层注入hook, 提取中间层输出的方法
2019/08/17 Python
python RC4加密操作示例【测试可用】
2019/09/26 Python
windows中安装Python3.8.0的实现方法
2019/11/19 Python
Django中使用MySQL5.5的教程
2019/12/18 Python
Python run()函数和start()函数的比较和差别介绍
2020/05/03 Python
python实现梯度下降算法的实例详解
2020/08/17 Python
加拿大最大的五金、家居装修和园艺产品商店:RONA
2017/01/27 全球购物
Nordgreen英国官网:斯堪的纳维亚设计师手表
2018/10/24 全球购物
介绍一下代理模式(Proxy)
2014/10/17 面试题
房屋买卖授权委托书
2014/09/27 职场文书
2014法院四风问题对照检查材料思想汇报
2014/10/04 职场文书
2015年试用期工作总结范文
2015/05/28 职场文书
《扇形统计图》教学反思
2016/02/17 职场文书