解决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 相关文章推荐
jQuery中实现动画效果的基本操作介绍
Apr 16 Javascript
jquery使用jquery.zclip插件复制对象的实例教程
Dec 04 Javascript
仿百度联盟对联广告实现代码
Aug 30 Javascript
Javascript动画的实现原理浅析
Mar 02 Javascript
jQuery实现可展开合拢的手风琴面板菜单
Sep 15 Javascript
js实现背景图自适应窗口大小
Jan 10 Javascript
vue中引用阿里字体图标的方法
Feb 10 Javascript
jQuery实现的点击标题文字切换字体效果示例【测试可用】
Apr 26 jQuery
vue实现点击追加选中样式效果
Nov 01 Javascript
Vue data的数据响应式到底是如何实现的
Feb 11 Javascript
JavaScript经典案例之简易计算器
Aug 24 Javascript
微信小程序实现左滑删除效果
Nov 18 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图片上传程序
2008/03/27 PHP
PHP的异常处理类Exception的使用及说明
2012/06/13 PHP
typecho插件编写教程(六):调用接口
2015/05/28 PHP
PHP策略模式定义与用法示例
2017/07/27 PHP
静态的动态续篇之来点XML
2006/08/15 Javascript
Mozilla 表达式 __noSuchMethod__
2009/04/05 Javascript
javascript 面向对象编程基础:封装
2009/08/21 Javascript
javascript针对DOM的应用分析(四)
2012/04/15 Javascript
jquery.ajax的url中传递中文乱码问题的解决方法
2014/02/07 Javascript
js统计页面的来访次数实现代码
2014/05/09 Javascript
js中将String转换为number以便比较
2014/07/08 Javascript
jQuery中:empty选择器用法实例
2014/12/30 Javascript
jquery判断checkbox是否选中及改变checkbox状态的实现方法
2016/05/26 Javascript
vue.js入门教程之绑定class和style样式
2016/09/02 Javascript
js实现带简单弹性运动的导航条
2017/02/22 Javascript
详解如何提高 webpack 构建 Vue 项目的速度
2017/07/03 Javascript
Three.js利用顶点绘制立方体的方法详解
2017/09/27 Javascript
VUE简单的定时器实时刷新的实现方法
2019/01/20 Javascript
深入解析koa之中间件流程控制
2019/06/17 Javascript
离线安装Pyecharts的步骤以及依赖包流程
2020/04/23 Python
利用Python实现微信找房机器人实例教程
2019/03/10 Python
使用Python快乐学数学Github万星神器Manim简介
2019/08/07 Python
python实现局域网内实时通信代码
2019/12/22 Python
matplotlib更改窗口图标的方法示例
2021/02/03 Python
Html5内唤醒百度、高德APP的实现示例
2019/05/20 HTML / CSS
阿迪达斯西班牙官方网站:adidas西班牙
2016/07/21 全球购物
英国最大的百货公司:Harrods
2016/08/18 全球购物
整个世界的设计师家具在哈恩:Designathome
2019/03/25 全球购物
如何选择使用结构还是类
2014/05/30 面试题
配置管理计划的主要内容有哪些
2014/06/20 面试题
《猴子种果树》教学反思
2014/04/26 职场文书
2014年教研员工作总结
2014/12/23 职场文书
大学生村官工作总结2015
2015/04/09 职场文书
被告答辩状范文
2015/05/22 职场文书
2016年党员承诺书范文
2016/03/24 职场文书
mapstruct的用法之qualifiedByName示例详解
2022/04/06 Java/Android