浅谈vue3 和 vue2的区别

  • vue3中不再导出一个Vue的构造函数,而是具名导出很多数据
  • 不给用户提供Vue构造函数来创建vue实例,使用一个具名导出的createApp,然后传入一个根组件来创建,然后返回一个类似于vue实例的对象,调用mount方法来实现挂载
  • 组件中兼容vue2的写法,只不过函数中的this指向不再是vue的组件实例,而是一个proxy代理对象。
  • vue3中同时增加了composition api的编程思想。
  • vue3中的组件可以不再单根
  • vite构建工具(同时也是一个脚手架)伴随着vue3的出现,与webpack相比,组件越多,vite的打包效率越快
    • 使用vite,引用文件时,除了.js文件不需要加后缀名,其他文件都需要添加上后缀名,否则vite无法识别
  • vue3 在编译时效率上的提升
    • 静态提升:vue3会识别组件中的一些没有绑定动态内容的静态节点,然后将这些节点编译过后,使用变量保存起来,之后再去重新生成虚拟dom时,不再创建,而是直接拿到之前保存的已经生成好的虚拟dom来使用;属性是静态时,也会将属性用变量保存起来,之后重新生成虚拟dom时会重用该变量

    • 预字符串化:当编译器遇到大量连续的静态内容,会直接将其编译为一个普通字符串节点

      const _hoisted_2 = _createStaticVNode("<div class="logo">

      logo

<ul
class="nav">
  • <a href="">menu
  • <a href="">menu
  • <a
    href="">menu
  • <a href="">menu
  • <a href="">menu
  • ")
  • 缓存事件处理函数:vue3中的render函数中传入了缓存对象_catch,这里面缓存了事件处理函数,这样在每次重新渲染时就不会重新生成一个一模一样的函数,减少内存开销

  • block tree:在vue3中,对比虚拟dom之前,会根节点中记录有哪些节点时动态节点,在对比时会直接对比记录的动态的节点,不会再去对比组件中的静态节点(如果虚拟dom树不稳定,则会进行其他处理)

  • patchFlag :在vue2中比对节点时,不知道那些发生了变化,只会一个个的对比,而在vue3中,记录了节点中哪些是动态的,真正需要比对的,所以在对比时,直接对比真正有可能发生变化的部分。
    未完待续...
    最后编辑于:2024-11-11 21:12:08
    © 著作权归作者所有,转载或内容合作请联系作者

  • 喜欢的朋友记得点赞、收藏、关注哦!!!

    相关推荐
    test猿2 分钟前
    hive为什么建表,表存储什么
    java
    程序猿零零漆1 小时前
    SpringCloud系列教程:微服务的未来(二十)Seata快速入门、部署TC服务、微服务集成Seata
    java·spring·spring cloud·微服务
    我的K84092 小时前
    Spring Boot基本项目结构
    java·spring boot·后端
    字节全栈_kYu2 小时前
    FastDFS实用笔记 (Docker 搭建环境 + 整合 SpringBoot)
    spring boot·笔记·docker
    码农小苏242 小时前
    K个不同子数组的数目--滑动窗口--字节--亚马逊
    java·数据结构·算法
    CodeClimb2 小时前
    【华为OD-E卷 - 最大矩阵和 100分(python、java、c++、js、c)】
    java·c++·python·华为od·矩阵
    独自破碎E3 小时前
    【4】阿里面试题整理
    java·开发语言·算法·排序算法·动态规划
    晴空๓3 小时前
    Spring Boot项目如何使用MyBatis实现分页查询
    spring boot·后端·mybatis
    heart000_14 小时前
    计算机毕业设计【任务书】怎么写?
    课程设计
    云山工作室7 小时前
    基于fpga技术的脉冲信号源设计(论文+源码)
    stm32·嵌入式硬件·fpga开发·毕业设计·毕设