当前位置: 首页 > news >正文

Vue2.0 双向绑定的缺陷

vue 实例创建后,无法检测到对象属性的新增或删除,只能追踪到数据是否被修改(Object.defineProperty只能劫持对象的属性),需要使用$set或者forceUpdate

不能监听数组的变化

vue在实现数组的响应式时,它使用了一些hack,把无法监听数组的情况通过重写数组的部分方法来实现响应式,这也只限制在数组的push/pop/shift/unshift/splice/sort/reverse七个方法

vue实现数组响应式的方法

申明一个对象arr,继承array.prototype,然后为其增加了数组的增删改排序和反转的方法,在使用这些方法的时候先调用array.prototype里面原来的方法对其数组进行操作,然后再触发视图更新的方法,在observe时就会先判断该元素是否是对象,是的话就把他的__proto__等于arr

通过重写数组的Array.prototype对应的方法,具体来说就是重新指定要操作数组的prototype,并重新该prototype中对应上面的7个数组方法,通过下面代码简单了解下实现原理:

const methods = ['pop','shift','unshift','sort','reverse','splice', 'push'];
// 复制Array.prototype,并将其prototype指向Array.prototype
let proto = Object.create(Array.prototype);
methods.forEach(method => {
    proto[method] = function () { // 重写proto中的数组方法
        Array.prototype[method].call(this, ...arguments);
        viewRender() // 视图更新
        function observe(obj) {
            if (Array.isArray(obj)) { // 数组实现响应式
                obj.__proto__ = proto; // 改变传入数组的prototype
                return;
            }
            if (typeof obj === 'object') {
                ... // 对象的响应式实现
            }
        }
    }
})

相关文章:

  • FDA药品分类目录清单查询
  • 总结——0923
  • 北鲲云“药物发现”轻装上阵,从“上云”到“用好云”
  • 微服务项目:尚融宝(55)(核心业务流程:放款(2))
  • 第七:Fiddler抓包教程(7)-Fiddler状态面板-QuickExec命令行
  • C++标准语言day02
  • 1456. 定长子串中元音的最大数目-前缀和算法应用
  • Spartan Labs研报:基础SBT以及隐私性SBT的实现
  • 【英语:基础进阶_语法进阶提升】F7.非谓语动词
  • jenkins教程
  • 《Java并发编程的艺术》——Java并发的前置知识(笔记)
  • 解决vs2022运行控制台项目提示:不知道如何运行名为xxxx和命令为Project的配置文件
  • 【SpringBoot2】02-SpringBoot中如何修改依赖的版本
  • Java Byte byteValue()方法的功能说明
  • 解决本地项目连接虚拟机redis进程失败【Failed connecting to host 6379】
  • [译] 怎样写一个基础的编译器
  • Android开源项目规范总结
  • Fabric架构演变之路
  • java概述
  • Node + FFmpeg 实现Canvas动画导出视频
  • PAT A1017 优先队列
  • React-flux杂记
  • Vue 动态创建 component
  • Vue全家桶实现一个Web App
  • 关于字符编码你应该知道的事情
  • 简单易用的leetcode开发测试工具(npm)
  • 前端 CSS : 5# 纯 CSS 实现24小时超市
  • 一天一个设计模式之JS实现——适配器模式
  • FaaS 的简单实践
  • ionic入门之数据绑定显示-1
  • k8s使用glusterfs实现动态持久化存储
  • ​​​​​​​sokit v1.3抓手机应用socket数据包: Socket是传输控制层协议,WebSocket是应用层协议。
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • #pragma预处理命令
  • (LeetCode) T14. Longest Common Prefix
  • (Matalb回归预测)PSO-BP粒子群算法优化BP神经网络的多维回归预测
  • (南京观海微电子)——COF介绍
  • (转)fock函数详解
  • .bat批处理(七):PC端从手机内复制文件到本地
  • .NET CF命令行调试器MDbg入门(二) 设备模拟器
  • .NET 中各种混淆(Obfuscation)的含义、原理、实际效果和不同级别的差异(使用 SmartAssembly)
  • .NET开源项目介绍及资源推荐:数据持久层 (微软MVP写作)
  • .考试倒计时43天!来提分啦!
  • [2016.7 Day.4] T1 游戏 [正解:二分图 偏解:奇葩贪心+模拟?(不知如何称呼不过居然比std还快)]
  • [Android]使用Android打包Unity工程
  • [C#]扩展方法
  • [cb]UIGrid+UIStretch的自适应
  • [LeetCode] 178. 分数排名
  • [Linux] 进程间通信基础
  • [Linux打怪升级之路]-信号的保存和递达
  • [mmucache]-ARMV8-aarch64的虚拟内存(mmutlbcache)介绍-概念扫盲
  • [NISACTF 2022]sign-ezc++
  • [NOI2014]购票
  • [OS-Linux] CentOS 7.x 使用密钥登录安全设置
  • [P3097] [USACO13DEC] [BZOJ4094] 最优挤奶Optimal Milking 解题报告(线段树+DP)