解决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 相关文章推荐
收藏一些不常用,但是有用的代码
Mar 12 Javascript
跨浏览器开发经验总结(四) 怎么写入剪贴板
May 13 Javascript
JS/Jquery判断对象为空的方法
Jun 11 Javascript
javascript+HTML5的Canvas实现Lab单车动画效果
Aug 07 Javascript
理解jquery事件冒泡
Jan 03 Javascript
jQuery基于muipicker实现仿ios时间选择
Feb 22 Javascript
JavaScript之WebSocket技术详解
Nov 18 Javascript
JS设计模式之策略模式概念与用法分析
Feb 05 Javascript
vue修改对象的属性值后页面不重新渲染的实例
Aug 09 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
Nov 14 Javascript
微信小程序云开发(数据库)详解
May 17 Javascript
vue 数据遍历筛选 过滤 排序的应用操作
Nov 17 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
一个简单计数器的源代码
2006/10/09 PHP
Laravel框架中自定义模板指令总结
2017/12/17 PHP
tp5.1 框架join方法用法实例分析
2020/05/26 PHP
Javascript中的delete操作符详细介绍
2014/06/06 Javascript
js和jquery中循环的退出和继续学习记录
2014/09/06 Javascript
JavaScript插件化开发教程(五)
2015/02/01 Javascript
JS动态显示表格上下frame的方法
2015/03/31 Javascript
js实现简单排列组合的方法
2016/01/27 Javascript
JavaScript修改作用域外变量的方法
2016/03/25 Javascript
angularjs使用directive实现分页组件的示例
2017/02/07 Javascript
详解react如何在组件中获取路由参数
2017/06/15 Javascript
vue.js整合vux中的上拉加载下拉刷新实例教程
2018/01/09 Javascript
Vue CLI3 开启gzip压缩文件的方式
2018/09/30 Javascript
jQuery无冲突模式详解
2019/01/17 jQuery
使用layui+ajax实现简单的菜单权限管理及排序的方法
2019/09/10 Javascript
Vue.extend 编程式插入组件的实现
2019/11/18 Javascript
JavaScript ECMA-262-3 深入解析(二):变量对象实例详解
2020/04/25 Javascript
[03:37]2015国际邀请赛第四日现场精彩集锦
2015/08/08 DOTA
[01:33]完美世界DOTA2联赛PWL S3 集锦第二期
2020/12/21 DOTA
异步任务队列Celery在Django中的使用方法
2018/06/07 Python
Flask之flask-session的具体使用
2018/07/26 Python
python单例模式实例解析
2018/08/28 Python
Python能做什么
2020/06/02 Python
解决Windows下python和pip命令无法使用的问题
2020/08/31 Python
施华洛世奇澳大利亚官网:SWAROVSKI澳大利亚
2017/01/06 全球购物
高品质和独特的产品世界:Creations and Collections
2018/01/07 全球购物
澳大利亚在线生活方式商店:Mytopia
2018/07/08 全球购物
波兰最大的度假胜地和城市公寓租赁运营商:Sun & Snow
2018/10/18 全球购物
护士试用期自我鉴定
2014/02/08 职场文书
残疾人小组计划书
2014/04/27 职场文书
行政执法作风整顿剖析材料
2014/10/11 职场文书
环卫处个人工作总结
2015/03/04 职场文书
工程合作意向书范本
2015/05/09 职场文书
职业规划从高考志愿专业选择开始
2019/08/08 职场文书
python中使用 unittest.TestCase单元测试的用例详解
2021/08/30 Python
总结高并发下Nginx性能如何优化
2021/11/01 Servers