网站首页 > 博客文章 正文
变异方法(去改变原数组):
Vue 包含一组观察数组的变异方法,所以它们也将会触发视图更新。这些方法如下:
- push()
- pop()
- shift()
- unshift()
- splice()
- sort()
- reverse()
为什么Vue官方文档只列举了这几个操作数组的方法?
替换数组(新数组覆盖原数组):
filter(), concat()和 slice() 。这些不会改变原始数组,但总是返回一个新数组。当使用这些非变异方法时,可以用新数组替换旧数组:
example1.items = example1.items.filter(function (item) { return item.message.match(/Foo/) })
为什么返回一个新数组也可以触发视图更新?
我们知道,由于 JavaScript 的限制,Vue 不能检测以下变动的数组:
1.当你利用索引直接设置一个项时,例如:vm.items[indexOfItem] = newValue
2.当你修改数组的长度时,例如:vm.items.length = newLength
举个例子:
var vm = new Vue({ data: { items: ['a', 'b', 'c'] } }) vm.items[1] = 'x' // 不是响应性的 vm.items.length = 2 // 不是响应性的
这是为什么呢?
这就要回到Vue的响应式原理:Object.defineProperty(obj, prop, descriptor)
,这个方法只能检测属性的变化.
举个例子:
var a = {}; bValue = 1; Object.defineProperty(a, "b", { set: function(value) { bValue = value; console.log("setted"); }, get: function() { return bValue; } }); a.b; //1 a.b = []; //setted a.b = [1, 2, 3]; //setted a.b[1] = 10; //无输出 a.b.push(4); //无输出 a.b.length = 5; //无输出 a.b; //[1,10,3,4,empty];
可以看出,a.b=[]或a.b=[1,2,3]等直接赋值引用类型是可以打印setted,即可以调用set方法。其他修改可以改变a.b的值,但无法调用set。这也是上述所说的"JavaScript 的限制",而不是Vue自身原因。
因此,变异方法的7个方法是Vue内部改造了,所以可以触发视图更新;替换数组的3个方法类似:
a.b = []; //setted a.b = [1, 2, 3]; //setted
进行覆盖,引用类型是可以触发setter,因此也可以触发视图更新。
另外:Vue文档说,Vue 为了使得 DOM 元素得到最大范围的重用而实现了一些智能的、启发式的方法,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作。
(个人猜测,未验证:假如a.b=[1,2,3,4,5,6,7,8,9],采用filter取偶数之后,a.b=[2,4,6,8]。那么新的数组元素2,4,6,8在原数组中的key保持不变,所以可以高效渲染DOM,至于怎么保持key不变,应当就是原文档的表述“最大范围的重用而实现了一些智能的、启发式的方法”,这个查阅源码才知道呢......)
猜你喜欢
- 2024-09-23 vue的数据驱动原理及简单实现(vue driver)
- 2024-09-23 分享:vue使用技巧和项目中遇到的问题
- 2024-09-23 「1分钟知识——前端01」vue双向绑定
- 2024-09-23 如何使用Vue中的嵌套插槽(包括作用域插槽)
- 2024-09-23 5.6 vue更新数组时触发视图更新的方法,熟记JavaScript原生方法
- 2024-09-23 学习Vue笔记012(3)- 列表渲染的注意
- 2024-09-23 vue更新数组时触发视图更新方法(vue中数组发生变化但视图没有更新)
- 2024-09-23 深入浅出 Vue Mixin(深入浅出全文免费阅读笔趣阁番外)
- 2024-09-23 Vue3 样式绑定: 内联样式与Class属性的数组语法
- 2024-09-23 vue 基础- mixins 多继承方式的代码复用
你 发表评论:
欢迎- 最近发表
-
- 给3D Slicer添加Python第三方插件库
- Python自动化——pytest常用插件详解
- Pycharm下安装MicroPython Tools插件(ESP32开发板)
- IntelliJ IDEA 2025.1.3 发布(idea 2020)
- IDEA+Continue插件+DeepSeek:开发者效率飙升的「三体组合」!
- Cursor:提升Python开发效率的必备IDE及插件安装指南
- 日本旅行时想借厕所、买香烟怎么办?便利商店里能解决大问题!
- 11天!日本史上最长黄金周来了!旅游万金句总结!
- 北川景子&DAIGO缘定1.11 召开记者会宣布结婚
- PIKO‘PPAP’ 洗脑歌登上美国告示牌
- 标签列表
-
- ifneq (61)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)