解决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 广告后加载,加载完页面再加载广告
Nov 25 Javascript
jquery中dom操作和事件的实例学习 下拉框应用
Dec 01 Javascript
减少访问DOM的次数提升javascript性能
Feb 24 Javascript
浅谈JavaScript 的执行顺序
Aug 07 Javascript
JS实现模拟百度搜索“2012世界末日”网页地震撕裂效果代码
Oct 31 Javascript
JavaScript仿商城实现图片广告轮播实例代码
Feb 06 Javascript
关于js原型的面试题讲解
Sep 25 Javascript
利用Node.JS实现邮件发送功能
Oct 21 Javascript
jquery手机触屏滑动拼音字母城市选择器的实例代码
Dec 11 jQuery
BootStrap中的模态框(modal,弹出层)功能示例代码
Nov 02 Javascript
VUE v-model表单数据双向绑定完整示例
Jan 21 Javascript
vue+element加入签名效果(移动端可用)
Jun 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
php的ajax简单实例
2014/02/27 PHP
Zend Framework教程之Zend_Db_Table用法详解
2016/03/21 PHP
php微信公众号js-sdk开发应用
2016/11/28 PHP
[原创]IE view-source 无法查看看源码 JavaScript看网页源码
2009/07/19 Javascript
什么是DOM(Document Object Model)文档对象模型
2012/03/05 Javascript
Chrome扩展页面动态绑定JS事件提示错误
2014/02/11 Javascript
基于jQuery日历插件制作日历
2016/03/11 Javascript
jquery插件uploadify多图上传功能实现代码
2016/08/12 Javascript
详解axios在vue中的简单配置与使用
2017/05/10 Javascript
Bootstrap Table使用整理(三)
2017/06/09 Javascript
JavaScript基本语法_动力节点Java学院整理
2017/06/26 Javascript
详解在Vue中如何使用axios跨域访问数据
2017/07/07 Javascript
前端常见跨域解决方案(全)
2017/09/19 Javascript
详解Nuxt.js Vue服务端渲染摸索
2018/02/08 Javascript
JavaScript中toLocaleString()和toString()的区别实例分析
2018/08/14 Javascript
element-ui 上传图片后清空图片显示的实例
2018/09/04 Javascript
实例介绍JavaScript中多种组合继承
2019/01/20 Javascript
深入Node TCP模块的理解
2019/03/13 Javascript
基于脚手架创建Vue项目实现步骤详解
2020/08/03 Javascript
Python迭代和迭代器详解
2016/11/10 Python
DataFrame中的object转换成float的方法
2018/04/10 Python
selenium跳过webdriver检测并模拟登录淘宝
2019/06/12 Python
Django 实现前端图片压缩功能的方法
2019/08/07 Python
PyCharm导入python项目并配置虚拟环境的教程详解
2019/10/13 Python
python每5分钟从kafka中提取数据的例子
2019/12/23 Python
Python 3.8 新功能大揭秘【新手必学】
2020/02/05 Python
Django实现任意文件上传(最简单的方法)
2020/06/03 Python
PyTorch中clone()、detach()及相关扩展详解
2020/12/09 Python
基于python+selenium自动健康打卡的实现代码
2021/01/13 Python
前端制作动画的几种方式(css3,js)
2016/12/12 HTML / CSS
HTML5 Canvas实现平移/放缩/旋转deom示例(附截图)
2013/07/04 HTML / CSS
美国生日蛋糕店:Bake Me A Wish!
2017/02/08 全球购物
StudentUniverse英国:学生航班、酒店和旅游
2019/08/25 全球购物
PHP开发的一般流程
2013/08/13 面试题
总经理助理岗位职责
2013/11/08 职场文书
高中数学教学反思范文
2016/02/18 职场文书