zoukankan      html  css  js  c++  java
  • 实现一个最小版本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
            },
          })
        })
      }
    }
    
  • 相关阅读:
    CCS样式命名
    BFC机制
    html及css小结
    盒模型
    C#函数的使用方法
    如何读代码
    利用CSS-border属性实现圆饼图表
    WNMP环境搭建(win10+Ndinx1.9.15+MySQL5.7.12+PHP5.6.21)
    vue 项目优化:引入cdn使用插件, 减少打包体积
    'PORT' 不是内部或外部命令,也不是可运行的程序
  • 原文地址:https://www.cnblogs.com/Evo1uti0n/p/13259588.html
Copyright © 2011-2022 走看看