2022-05-22

1.vue3复习

1.性能的提升

  打包大小减少41%

  初次渲染快55%, 更新渲染快133%

  内存减少54%

2.源码的升级

  使用Proxy代替defineProperty实现响应式

  重写虚拟DOM的实现和Tree-Shaking

3.拥抱TypeScript

Vue3可以更好的支持TypeScript

4.新的特性

1.  Composition API(组合API)

  setup配置

    ■ 返回值

      1. 若返回一个对象,则对象中的属性、方法, 在模板中均可以直接使用。(重点关注!)

      2. 若返回一个渲染函数:则可以自定义渲染内容。(了解)

  ref与reactive

  watch与watchEffect

  provide与inject

2.  新的内置组件

  Fragment

  Teleport

  Suspense

3.  其他改变

  新的生命周期钩子

  data 选项应始终被声明为一个函数

  移除keyCode支持作为 v-on 的修饰符

2.虚拟dom的创建

https://juejin.cn/post/6844903895467032589#heading-9

在 Vue.js 中,Virtual DOM 是用 VNode 这个 Class 去描述

VNode的属性:

tag 属性即这个vnode的标签属性

data 属性包含了最后渲染成真实dom节点后,节点上的class,attribute,style以及绑定的事件

children 属性是vnode的子节点

text 属性是文本属性

elm 属性为这个vnode对应的真实dom节点

key 属性是vnode的标记,在diff过程中可以提高diff的效率

创建VNode的过程

初始化vue

new Vue( ) 时,实际上是执行 src/core/instance/index.js  中定义的函数

function Vue (options) {

  if (process.env.NODE_ENV !== 'production' &&

    !(this instanceof Vue)

  ) {

    warn('Vue is a constructor and should be called with the `new` keyword')

  }

  this._init(options)

}

  Vue.prototype._init = function (options?: Object) {

    const vm: Component = this

     

    // 省略一系列其它初始化的代码

     

    if (vm.$options.el) {

      console.log('vm.$options.el:',vm.$options.el);

      vm.$mount(vm.$options.el)

    }

  }

Vue实例挂载

$mount 方法实际上会去调用 mountComponent 方法

export function mountComponent (

  vm: Component,

  el: ?Element,

  hydrating?: boolean

): Component {

  vm.$el = el

  // 省略一系列其它代码

  let updateComponent

  /* istanbul ignore if */

  if (process.env.NODE_ENV !== 'production' && config.performance && mark) {

    updateComponent = () => {

      // 生成虚拟 vnode 

      const vnode = vm._render()

      // 更新 DOM

      vm._update(vnode, hydrating)

   

    }

  } else {

    updateComponent = () => {

      vm._update(vm._render(), hydrating)

    }

  }


  // 实例化一个渲染Watcher,在它的回调函数中会调用 updateComponent 方法 

  new Watcher(vm, updateComponent, noop, {

    before () {

      if (vm._isMounted && !vm._isDestroyed) {

        callHook(vm, 'beforeUpdate')

      }

    }

  }, true /* isRenderWatcher */)

  hydrating = false


  return vm

}

mountComponent 核心就是先实例化一个渲染Watcher,在它的回调函数中会调用 updateComponent 方法,在此方法中调用 vm._render 方法先生成虚拟 Node,最终调用 vm._update 更新 DOM。

你可能感兴趣的:(2022-05-22)