Vue2.x 与Vue3.x 双向数据绑定区别

栏目: JavaScript · 发布时间: 5年前

内容简介:看过Vue2.x的源码都知道,其双向数据绑定原理是通过es5的Object.defineProperty,中的set方法来实现数据劫持的,但是有一个弊端就是无法兼听到数组内部的数据变化(当然我们可以通过arr = arr.concat([])),来实现内部数据变化的检测。相比Vue3有一定的性能问题。Vue3.x是用ES6的语法 Proxy(Proxy 怎么用大家可自行百度,网上教程大把,我就不在这赘述了)对象来实现的,这个玩意儿也可以实现数据的劫持,相比Object.defineProperty的优势是:

Vue2.x 与Vue3.x 双向数据绑定区别

看过Vue2.x的源码都知道,其双向数据绑定原理是通过es5的Object.defineProperty,中的set方法来实现数据劫持的,但是有一个弊端就是无法兼听到数组内部的数据变化(当然我们可以通过arr = arr.concat([])),来实现内部数据变化的检测。相比Vue3有一定的性能问题。

Vue3.x是用ES6的语法 Proxy(Proxy 怎么用大家可自行百度,网上教程大把,我就不在这赘述了)对象来实现的,这个玩意儿也可以实现数据的劫持,相比Object.defineProperty的优势是:可以检测到数组内部数据的变化,如下图:

![图片上传中...]

Vue2.x 与Vue3.x 双向数据绑定区别

据说proxy要比Object.defineProperty的内存减半,vue3.x还没正式发布,我也只是听说,听说哈,减不减半我不知道也不敢下结论。

Vue2.x 与Vue3.x 双向数据绑定区别

你以为这就完了吗?哈哈哈哈,你没猜错,IE系列都不兼容Proxy,哈哈哈哈哈。

Vue2.x 与Vue3.x 双向数据绑定区别

But

Vue2.x 与Vue3.x 双向数据绑定区别

社会是要向前进的,这点相信尤大大已经为我们考虑到了,肯定会有向下兼容的方案,那就是用原始的Object.defineProperty咯。

写在最后:大家不管学什么框架,一定要尝试去读下别人的源码,不要一上来就vue-cli 就咔咔咔开撸。如果每个前端都会vue-cli的话,那请问你的竞争力在哪?

最后希望我的分享能够帮助到大家。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Pro JavaScript Design Patterns

Pro JavaScript Design Patterns

Dustin Diaz、Ross Harmes / Apress / 2007-12-16 / USD 44.99

As a web developer, you’ll already know that JavaScript™ is a powerful language, allowing you to add an impressive array of dynamic functionality to otherwise static web sites. But there is more power......一起来看看 《Pro JavaScript Design Patterns》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具