【Vue温故】粗略实现VUE源码data与method

一.Method遗漏概念

1.Vue创建实例时,会自动为methods绑定当前实例this,保证在事件监听时,回调始终指向当前组件实例

2.方法要避免使用箭头函数,箭头函数会阻止Vue正确绑定组件实例this

二.粗略实现代理与Method对象

let Vue = (function(){
  function Vue(options){
      this.$data = options.data();
      this._methods = options.methods;
      this._init(this)
    }
    Vue.prototype._init = function(vm){
      initData(vm);
      initMethods(vm);
    }
    function initData(vm){
      for(var key in vm.$data){
        (
          function(key){
            Object.defineProperty(vm,key,{
              get:function(){
                return vm.$data[key]
              },
              set:function(newValue){
                vm.$data[key] = newValue
              }
            })
          }
        )(key)
      } 
    }
    function initMethods(vm){
      for(var key in vm._methods){
        vm[key] = vm._methods[key]
      }
    }
    return Vue;

})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值