第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

vue源碼探究(第三彈)

標(biāo)簽:
Html/CSS Vue.js vuex

结束了之前prepare,现在开始正式进入vue源码探究部分

数据代理

先从简单的入手,我们先手动实现一个简易版的数据代理吧。

基础知识

  1. vue数据代理: data对象的所有属性的操作(读/写)由vm对象来代理操作

  2. 好处: 通过vm对象就可以方便的操作data中的数据

  3. 实现:
    1). 通过Object.defineProperty(vm, key, {})给vm添加与data对象的属性对应的属性
    2). 所有添加的属性都包含get/set方法
    3). 在get/set方法中去操作data中对应的属性

举个例子

<div id="test"></div><script type="text/javascript" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="js/mvvm/compile.js"></script><script type="text/javascript" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="js/mvvm/mvvm.js"></script><script type="text/javascript" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="js/mvvm/observer.js"></script><script type="text/javascript" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="js/mvvm/watcher.js"></script><script type="text/javascript">
  // 这里取名为mvvm 是因为在mvvm.js中 
  // 是这样暴露的 function MVVM(options) {} 这里的MVVM和vue是一样的 只是一个命名的问题
  const vm = new MVVM({
    el: "#test",
    data: {
      name: '张三2'
    }
  })
  console.log(vm.name)  // 读取的是data中的name,  vm代理对data的读操作
  vm.name = '李四2' // 数据保存到data中的name上, vm代理对data的写操作
  console.log(vm.name, vm._data.name) // 李四2 李四2</script>

上面这部分是为了简单说明,我们写的mvvm实现了简单的数据代理,接下来,我们来剖析一下它的内部实现。
先揭一个底,它的核心实现就是之前讲过的Object.defineProperty

/*相关于Vue的构造函数 */function MVVM(options) {
  // 将选项对象保存到vm  this.$options = options;
  // 将data对象保存到vm和datq变量中  var data = this._data = this.$options.data;
  //将vm保存在me变量中  var me = this;
  // 遍历data中所有属性  Object.keys(data).forEach(function (key) { // 属性名: name    // 对指定属性实现代理    me._proxy(key);
  });

  // 对data进行监视  observe(data, this);

  // 创建一个用来编译模板的compile对象  this.$compile = new Compile(options.el || document.body, this)}MVVM.prototype = {
  $watch: function (key, cb, options) {
    new Watcher(this, key, cb);
  },

  // 对指定属性实现代理  _proxy: function (key) {
    // 保存vm    var me = this;
    // 给vm添加指定属性名的属性(使用属性描述)    Object.defineProperty(me, key, {
      configurable: false, // 不能再重新定义      enumerable: true, // 可以枚举      // 当通过vm.name读取属性值时自动调用      get: function proxyGetter() {
        // 读取data中对应属性值返回(实现代理读操作)        return me._data[key];
      },
      // 当通过vm.name = 'xxx'时自动调用      set: function proxySetter(newVal) {
        // 将最新的值保存到data中对应的属性上(实现代理写操作)        me._data[key] = newVal;
      }
    });
  }};

Tips:

在源码学习的过程中,掌握到了一个小技巧,读源码的时候,debugger会更加的方便。


5cd61f460001ee7407200475.jpg


image.png


5cd61f460001fb6606620328.jpg


image.png

非常好用,我之前太蠢了,只会第一个resume script execution

最后

未完待续...
接下来,还有一个更有趣的东西

下一章继续~


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶(hù)
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專(zhuān)欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消