【VUE】源码分析 - 数据劫持的基本原理

tips:本系列博客的代码部分(示例等除外),均出自vue源码内容,版本为2.6.14。但是为了增加易读性,会对不相关内容做选择性省略。如果大家想了解完整的源码,建议自行从官方下载。https://github.com/vuejs/vuehttps://github.com/vuejs/vue

本系列博客 ( 不定期更新 ):

【VUE】源码分析 - computed计算属性的实现原理_依然范特西fantasy的博客-优快云博客

【VUE】源码分析 - watch侦听器的实现原理_依然范特西fantasy的博客-优快云博客

【VUE】源码分析 - 数据劫持的基本原理_依然范特西fantasy的博客-优快云博客

一,基本实现原理

1,核心原理:defineProperty 和 Array的实例方法劫持

defineProperty是JS的元编程手段之一。Object类型,可以通过defineProperty来实现对数据的劫持监听。

vue中的defineReactive函数正是做了这样一件事。其简化形式如下:

function defineReactive(obj, key, val) {
  Object.defineProperty(obj, key, {
    enumerable: true,
    configurable: true,
    get() {
      //收集依赖
      return val
    },
    set(newValue) {
      //触发依赖
      val = newValue
    },
  });
}

通过对obj的defineProperty,在其get和set函数中做了某些操作,其中就包括了依赖的收集,和对依赖的触发。get和set函数对defineReactive函数闭包中val的操作,从而实现私有变量的对外隐蔽。

而对于数组类型的数据劫持,vue给出的方案是对其某些实例方法的进行劫持。

const methodsToPatch = [
  "push",
  "pop",
  "shift",
  "unshift",
  "splice",
  "sort",
  "reverse",
];

methodsToPatch.forEach(function (method) {
  const original = Array.property[method];
  def(arrayMethods, method, function mutator(...args) {
    //拦截Array的几个原型方
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值