美文网首页
2022-05-22

2022-05-22

作者: 姜浩_19强化班 | 来源:发表于2022-05-22 23:51 被阅读0次

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

    2022-05-22(周日) 戒定慧·《感恩日志》重启第09天 【14:07】 01、感恩:今日能基本结束“居家闭...

  • 2022-05-23

    2022-05-22 【日精进打卡第1549天】 【知~学习】 《六项精进》 《大学》 【读书】 1、《董明珠传》...

  • 构成良好目标的特征

    中原焦点团队 坚持分享1407天 2022-05-22 一、焦点解决的工作结构 梦想(或问题)、目标、例外、一...

  • 2022-05-22 思考成长周复盘(第100/130周)

    一 时间 2021-05-16 ~ 2022-05-22 二 行动回顾与反思 1 生活作息(2022年度早起目标:...

  • 《惠此中国:作为一个神性概念的中国》读书笔记

    2022-05-22 16:31:28 中国能够像一个“世界”那样存在,具有“世界性”的容纳能力,能以“不是之是”...

  • 依赖性

    杨素芳 中原焦点团队 高五 坚持分享1583天 2022-05-22 人是群居动物,相互之间需要依赖,相互...

  • 2022-05-22

    Sci Imm | 雄激素与CD8+T细胞衰竭程序合并导致癌症性差异 图灵基因图灵基因2022-05-22 21:...

  • 真实故事:对门来了捉奸的正房,他才知道自己爱的是“外围女”

    真实故事:对门来了捉奸的正房,他才知道自己爱的是“外围女” 2022-05-22 15:08·中原琪琪格[http...

  • 我读《长安的荔枝》

    2022-05-22 阴有雨 周日 上个月在网络,很偶然地看到有人在介绍马伯庸的短篇小说《长...

  • 2022-05-22

    Nat MI | GPU计算和深度学习在药物发现中的推动作用 原创风不止步图灵基因2022-05-22 21:24...

网友评论

      本文标题:2022-05-22

      本文链接:https://www.haomeiwen.com/subject/szwlprtx.html