实现一个最小版本vue(一)之Vue

Vue

功能

  • 负责接收初始化的参数
  • 负责把data中的属性注入到vue实例,转化称getter,setter
  • 负责调用observer监听data中所有属性的变化
  • 负责调用compiler解析指令/差值表达式
  • 结构

实现思路

  1. 通过属性保存选项的数据
  2. 把data中的成员转化称getter和setter,注入到vue实例,方便后续使用
  3. 调用observer对象,监听数据变化
  4. 调用compiler对象,解析指令和差值表达式。compiler实现

代码

class Vue {
  constructor (options) {
    // 1.通过属性保存选项的数据
    this.$options = options || {}
    this.$data = options.data || {}
    this.$el = typeof options.el === 'string' ? document.querySelector(options.el) : options.el
    // 2.把data中的成员转化成getter和setter,注入到vue实例
    this._proxyData(this.$data)
    // 3. 调用observer对象,把data中的属性转换称getter和setter,还有监听数据变化等其他事情
    new Observer(this.$data)
    // 4.调用compiler对象,解析指令和差值表达式
    new Compiler(this)
  }

  // 代理传入的数据
  _proxyData (data) {
    // 遍历data中所有属性
    Object.keys(data).forEach(key => {
      // 把data的属性注入到vue实例
      Object.defineProperty(this, key, {
        enumerable: true,
        configurable: true,
        get () {
          return data[key]
        },
        set (newValue) {
          if (newValue === data[key]) {
            return
          }
          data[key] = newValue
        },
      })
    })
  }
}
posted @ 2020-07-07 11:03  Evo1uti0n  阅读(265)  评论(0编辑  收藏  举报