温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

angular脏值检测与vue数据劫持有哪些区别

发布时间:2020-12-17 09:33:23 来源:亿速云 阅读:450 作者:小新 栏目:web开发

这篇文章主要介绍了angular脏值检测与vue数据劫持有哪些区别,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

区别:1、angular脏值检测原理上支持低端IE,理论上兼容性更好;vue数据劫持需要支持ES5的浏览器。2、angular脏值检测适合大数据量的更新;vue数据劫持适合小数据量的更新。

实现数据绑定的做法有大致如下几种:

  • 发布者-订阅者模式(backbone.js)

  • 脏值检查(angular.js)

  • 数据劫持(vue.js)

angular中的脏值检测

angular.js 是通过脏值检测的方式比对数据是否有变更,来决定是否更新视图,最简单的方式就是通过 setInterval() 定时轮询检测数据变动,当然Google不会这么low,angular只有在指定的事件触发时进入脏值检测,大致如下:

  • DOM事件,譬如用户输入文本,点击按钮等。( ng-click )

  • XHR响应事件 ( $http )

  • 浏览器Location变更事件 ( $location )

  • Timer事件( interval )

  • 执行 apply()

优缺点

  • 原理上支持低端IE(记得最早的NG支持IE8),理论上兼容性更好

  • 适合大数据量的更新,CPU层面的时间复杂度为O(VModel),小量更新的diff有计算浪费

  • 可考虑配合类Immutable.js的轮子和思想优化,类似React + Redux + Immer

  • 需要手动调用,同setState,引入Zone.js后方便一些,大颗粒度更新都有这个问题

vue中的数据劫持

数据劫持主要通过 ES5 提供的Object.defineProperty方法来实现,监控对数据的操作,从而可以自动触发数据同步。并且,由于是在不同的数据上触发同步,可以精确的将变更发送给绑定的视图,而不是对所有的数据都执行一次检测。

数据与视图的绑定与同步,最终体现在对数据的读写处理过程中,也就是 Object.defineProperty() 定义的数据 set、get 函数中。

优缺点

  • 使用JavaScript原生特性,但也需要支持ES5的浏览器,毕竟前端面向未来编程,所以Vue 3计划升级到ES6的Proxy实现

  • 适合小数据量(细颗粒度)的更新 ,CPU层面的时间复杂度为O(Change),代价是更多的内存占用(空间换时间)

  • 减少依赖收集的颗粒度(从关心某属性变了,改为只关心某对象变了)能优化内存问题

  • 其实Vue 2就是通过引入Virtual DOM,改为在子组件层面用diff的方式更新

两者区别

angular脏值检测原理上支持低端IE(记得最早的NG支持IE8),理论上兼容性更好;而vue数据劫持需要支持ES5的浏览器。

angular脏值检测适合大数据量的更新;而vue数据劫持适合小数据量(细颗粒度)的更新。

感谢你能够认真阅读完这篇文章,希望小编分享angular脏值检测与vue数据劫持有哪些区别内容对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,遇到问题就找亿速云,详细的解决方法等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI