Vue3笔记(一)

简介: 从vue2到vue3

1、从vue2到vue3


网上一搜,比较官方的区别如下:

  • vue2对TS支持不友好(所有属性都放在this对象上,用ts难以推断组件的数据类型)
  • 大量的API挂载在Vue的原型上,难以实现TreeShaking。
  • CompositionAPI 受ReactHook启发(均是函数不是类)
  • vue2在架构层面对跨平台dom渲染开发支持不友好
  • 对虚拟Dom进行了重写,对模板的编译进行了优化操作


在使用vue3之后可以明显感受到以下几点变化:

1、使用Composition API,更加方便。业务数据与业务逻辑可以整合写到一起。

2、不存在this使用,直接通过函数调用。

3、性能比vue2快。

4、更加友好的支持TS。

5、兼容Vue2。Composition API可以和Option API混合使用。


2、vue3性能优化原因


1、diff算法优化


在vue2中,虚拟dom是进行全量的对比。而vue3中使用静态标记实现懒比较。

编译时先生成dom树,vue3在含有变量的节点添加flag标记,在比较时,只需要比较带有标记的元素节点。这样大大减少了对比量。 可以使用此网站查看vue3的编译部分源码。

示例

使用上文网站进行编译:

<div>
  <p>{{name}}</p>
</div>

编译之后:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createBlock("div", null, [
    _createVNode("p", null, _toDisplayString(_ctx.name), 1 /* TEXT */) // 1 代表动态文本节点 PatchFlag附文末
  ]))
}


2、hoistStatic静态提升


vue2中无论元素是否参与更新,每次都会重新创建、然后再渲染。vue3中对于不参与更新的元素会做静态提升,只会被创建一次,在渲染时直接复用既可。

示例

使用上文网站进行编译:

<div>
  <p>111</p>
  <p>222</p>
  <p>233</p>
  <p>{{name}}</p>
</div>

静态提升之前:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createBlock("div", null, [
    _createVNode("p", null, "111"),
    _createVNode("p", null, "222"),
    _createVNode("p", null, "233"),
    _createVNode("p", null, _toDisplayString(_ctx.name), 1 /* TEXT */)
  ]))
}

静态提升之后:

const _hoisted_1 = /*#__PURE__*/_createVNode("p", null, "111", -1 /* HOISTED */)
const _hoisted_2 = /*#__PURE__*/_createVNode("p", null, "222", -1 /* HOISTED */)
const _hoisted_3 = /*#__PURE__*/_createVNode("p", null, "233", -1 /* HOISTED */)
export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createBlock("div", null, [
    _hoisted_1,
    _hoisted_2,
    _hoisted_3,
    _createVNode("p", null, _toDisplayString(_ctx.name), 1 /* TEXT */)
  ]))
}

总结一句话:把不需要参与更新的元素放到外面定义,只需要创建一次


3、cachHadlers 事件侦听器缓存


在默认情况下onClick会被视为动态绑定,每次都要去追踪事件变化。但是在vue3中,视为同一个函数,所以不会追踪其变化,直接缓存起来使用即可。

示例

使用上文网站进行编译:

<div>
  <button @click="btn"></button>
</div>
复制代码

事件侦听之前(静态标记: 8):

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createBlock("div", null, [
    _createVNode("button", { onClick: _ctx.btn }, null, 8 /* PROPS */, ["onClick"])
  ]))
}
复制代码

事件侦听之后:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createBlock("div", null, [
    _createVNode("button", {
      onClick: _cache[1] || (_cache[1] = (...args) => (_ctx.btn && _ctx.btn(...args)))
    })
  ]))
}
复制代码


4、ssr渲染


  • 当有大量静态的内容时候,这些呢容会被当做纯字符串推进一个buffer里面,即使存在动态的绑定,也会通过模板插值嵌进去。这样会比通过虚拟dom来渲染的快上很多
  • 当静态内容大到一定量级的时候,会用_createStaticVNode方法在客户端去生成一个static node,这些静态node,会被直接innnerHTML,就不需要创建对象,然后根据对象渲染。

附PatchFlag标记:

TEXT = 1;       // 1  动态文本节点
CLASS = 1 << 1, // 2 动态class
STYLE = 1 << 2, // 4 动态style
PROPS = 1 << 3, // 8 动态属性,但不包含类名和样式
FULL_PROPS = 1 << 4, // 16 具有动态key属性,当 key 需要改变时,需要进行完整的diff比较
HYDRATE_EVENTS = 1 << 5, // 32 带有监听事件的节点
STABLE_FRAGMENT = 1 << 6, // 64 一个不会改变子节点顺序的 fragment
KEYED_FRAGMENT = 1 << 7, // 128 带有key属性的fragment 或 部分子节点有key
UNKEYED_FRAGMENT = 1 << 8, // 256 子节点没有key的fragment
NEED_PATCH = 1 << 9, // 512 一个节点只会进行非 props比较


作者:ClyingDeng

链接:https://juejin.cn/post/6926714564864114701

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

目录
相关文章
|
2月前
|
缓存 JavaScript PHP
斩获开发者口碑!SnowAdmin:基于 Vue3 的高颜值后台管理系统,3 步极速上手!
SnowAdmin 是一款基于 Vue3/TypeScript/Arco Design 的开源后台管理框架,以“清新优雅、开箱即用”为核心设计理念。提供角色权限精细化管理、多主题与暗黑模式切换、动态路由与页面缓存等功能,支持代码规范自动化校验及丰富组件库。通过模块化设计与前沿技术栈(Vite5/Pinia),显著提升开发效率,适合团队协作与长期维护。项目地址:[GitHub](https://github.com/WANG-Fan0912/SnowAdmin)。
419 5
|
2月前
|
JavaScript API 容器
Vue 3 中的 nextTick 使用详解与实战案例
Vue 3 中的 nextTick 使用详解与实战案例 在 Vue 3 的日常开发中,我们经常需要在数据变化后等待 DOM 更新完成再执行某些操作。此时,nextTick 就成了一个不可或缺的工具。本文将介绍 nextTick 的基本用法,并通过三个实战案例,展示它在表单验证、弹窗动画、自动聚焦等场景中的实际应用。
179 17
|
3月前
|
JavaScript 前端开发 算法
Vue 3 和 Vue 2 的区别及优点
Vue 3 和 Vue 2 的区别及优点
|
3月前
|
存储 JavaScript 前端开发
基于 ant-design-vue 和 Vue 3 封装的功能强大的表格组件
VTable 是一个基于 ant-design-vue 和 Vue 3 的多功能表格组件,支持列自定义、排序、本地化存储、行选择等功能。它继承了 Ant-Design-Vue Table 的所有特性并加以扩展,提供开箱即用的高性能体验。示例包括基础表格、可选择表格和自定义列渲染等。
197 6
|
2月前
|
JavaScript 前端开发 API
Vue 2 与 Vue 3 的区别:深度对比与迁移指南
Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,在过去的几年里,Vue 2 一直是前端开发中的重要工具。而 Vue 3 作为其升级版本,带来了许多显著的改进和新特性。在本文中,我们将深入比较 Vue 2 和 Vue 3 的主要区别,帮助开发者更好地理解这两个版本之间的变化,并提供迁移建议。 1. Vue 3 的新特性概述 Vue 3 引入了许多新特性,使得开发体验更加流畅、灵活。以下是 Vue 3 的一些关键改进: 1.1 Composition API Composition API 是 Vue 3 的核心新特性之一。它改变了 Vue 组件的代码结构,使得逻辑组
491 0
|
4月前
|
JavaScript 前端开发 UED
vue2和vue3的响应式原理有何不同?
大家好,我是V哥。本文详细对比了Vue 2与Vue 3的响应式原理:Vue 2基于`Object.defineProperty()`,适合小型项目但存在性能瓶颈;Vue 3采用`Proxy`,大幅优化初始化、更新性能及内存占用,更高效稳定。此外,我建议前端开发者关注鸿蒙趋势,2025年将是国产化替代关键期,推荐《鸿蒙 HarmonyOS 开发之路》卷1助你入行。老项目用Vue 2?不妨升级到Vue 3,提升用户体验!关注V哥爱编程,全栈开发轻松上手。
242 2
|
4月前
|
JavaScript 前端开发 算法
高效工作流:用Mermaid绘制你的专属流程图;如何在Vue3中导入mermaid绘制流程图
mermaid是一款非常优秀的基于 JavaScript 的图表绘制工具,可渲染 Markdown 启发的文本定义以动态创建和修改图表。非常适合新手学习或者做一些弱交互且自定义要求不高的图表 除了流程图以外,mermaid还支持序列图、类图、状态图、实体关系图等图表可供探索。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
4月前
|
JavaScript 前端开发 API
你真的会使用Vue3的onMounted钩子函数吗?Vue3中onMounted的用法详解
onMounted作为vue3中最常用的钩子函数之一,能够灵活、随心应手的使用是每个Vue开发者的必修课,同时根据其不同写法的特性,来选择最合适最有利于维护的写法。博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
4月前
|
资源调度 JavaScript 前端开发
Pinia 如何在 Vue 3 项目中进行安装和配置?
Pinia 如何在 Vue 3 项目中进行安装和配置?
317 4
|
4月前
|
JavaScript 前端开发 API
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~