解决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 相关文章推荐
js中replace的用法总结
Dec 27 Javascript
为JS扩展Array.prototype.indexOf引发的问题及解决办法
Jan 21 Javascript
JavaScript调用传递变量参数的相关问题及解决办法
Nov 01 Javascript
jQuery中弹出iframe内嵌页面元素到父页面并全屏化的实例代码
Dec 27 Javascript
Vue组件模板形式实现对象数组数据循环为树形结构(实例代码)
Jul 31 Javascript
vue获取input输入值的问题解决办法
Oct 17 Javascript
详述 Sublime Text 打开 GBK 格式中文乱码的解决方法
Oct 26 Javascript
VueJs 搭建Axios接口请求工具
Nov 20 Javascript
JavaScript控制浏览器全屏显示简单示例
Jul 05 Javascript
React Router V4使用指南(精讲)
Sep 17 Javascript
解决Vue在Tomcat8下部署页面不加载的问题
Nov 12 Javascript
一文帮你理解PReact10.5.13源码
Apr 03 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/11/16 PHP
PHP file_exists问题杂谈
2012/05/07 PHP
zeroclipboard复制到剪切板的flash
2010/08/04 Javascript
javascript中的onkeyup和onkeydown区别介绍
2013/04/28 Javascript
window.location.href中url中数据量太大时的解决方法
2013/12/23 Javascript
JavaScript声明变量名的语法规则
2015/07/10 Javascript
js游戏人物上下左右跑步效果代码分享
2015/08/28 Javascript
Jquery 垂直多级手风琴菜单附源码下载
2015/11/17 Javascript
基于JavaScript如何实现ajax调用后台定义的方法
2015/12/29 Javascript
Boostrap基础教程之JavaScript插件篇
2016/09/08 Javascript
微信小程序开发之Tabbar实例详解
2017/01/09 Javascript
解决Mac node版本升级失败的问题
2018/05/16 Javascript
vue和webpack打包项目相对路径修改的方法
2018/06/15 Javascript
Vue.js获取被选择的option的value和text值方法
2018/08/24 Javascript
原生JS实现简单的无缝自动轮播效果
2018/09/26 Javascript
vue实现简单的日历效果
2020/09/24 Javascript
JS将时间秒转换成天小时分钟秒的字符串
2019/07/10 Javascript
Node.js API详解之 net模块实例分析
2020/05/18 Javascript
tornado捕获和处理404错误的方法
2014/02/26 Python
Python操作json数据的一个简单例子
2014/04/17 Python
Python中函数及默认参数的定义与调用操作实例分析
2017/07/25 Python
tensorflow使用神经网络实现mnist分类
2018/09/08 Python
python执行CMD指令,并获取返回的方法
2018/12/19 Python
Python random模块制作简易的四位数验证码
2020/02/01 Python
在Python中通过threshold创建mask方式
2020/02/19 Python
Html5中的桌面通知Notification的实现
2018/09/25 HTML / CSS
用Python写一个for循环的例子
2016/07/19 面试题
入职担保书范文
2014/05/21 职场文书
学校四群教育实施方案
2014/06/12 职场文书
销售经理工作失职检讨书
2014/10/24 职场文书
2014年安全保卫工作总结
2014/11/13 职场文书
违纪检讨书范文
2015/01/27 职场文书
个人更名证明
2015/06/23 职场文书
幼儿园卫生保健制度
2015/08/05 职场文书
2016年党员创先争优承诺书
2016/03/25 职场文书
利用 Python 的 Pandas和 NumPy 库来清理数据
2022/04/13 Python