2025年vue3和vue2的优缺点(vue3和vue2有什么区别)

vue3和vue2的优缺点(vue3和vue2有什么区别)div id navCategory div 我们使用 vue2 常常会遇到一些体验不太好的地方 比如 随着功能的增长 需求的增加 复杂组件的代码越来越难以维护 逻辑混乱 虽然 vue2 也有一些复用的方法 但是都存在一定的弊端 比如我们常常用的 Mixin 特别容易发生命名冲突 暴露出来的变量意图不是很明显 重用到其他组件容易冲突

大家好,我是讯享网,很高兴认识大家。



 <div id="navCategory"></div> 

讯享网

我们使用vue2常常会遇到一些体验不太好的地方,比如:

  1. 随着功能的增长,需求的增加,复杂组件的代码越来越难以维护,逻辑混乱,虽然vue2也有一些复用的方法,但是都存在一定的弊端,比如我们常常用的Mixin,特别容易发生命名冲突,暴露出来的变量意图不是很明显,重用到其他组件容易冲突。
  2. vue2对于typeScript的支持非常有限,没有考虑到ts的集成。

vue3的出现就是为了解决vue2的弊端,其composition API很好的解决了逻辑复用的问题,而且vue3源码就是用ts写的,对ts的支持非常好。我们在开发项目过程中可以使用ts的加持,使代码更加健壮。

  1. vue3支持vue2的大多数特性,实现对vue2的兼容
  2. vue3对比vue2具有明显的性能提升
    1. 打包大小减少41%
    2. 初次渲染快55%,更新快133%
    3. 内存使用减少54%
  3. vue3具有的composition API实现逻辑模块化和重用
  4. 增加了新特性,如Teleport组件,全局API的修改和优化等

Vue2.x实现双向数据绑定原理,是通过es5的 Object.defineProperty,根据具体的key去读取和修改。其中的setter方法来实现数据劫持的,getter实现数据的修改。但是必须先知道想要拦截和修改的key是什么,所以vue2对于新增的属性无能为力,比如无法监听属性的添加和删除、数组索引和长度的变更,vue2的解决方法是使用Vue.set(object, propertyName, value) 等方法向嵌套对象添加响应式。

Vue3.x使用了ES2015的更快的原生proxy 替代 Object.defineProperty。Proxy可以理解成,在对象之前架设一层“拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机制,可以对外界的访问进行过滤和改写。Proxy可以直接监听对象而非属性,并返回一个新对象,具有更好的响应式支持

beforeCreate -> 请使用 setup()

created -> 请使用 setup()

beforeMount -> onBeforeMount

mounted -> onMounted

beforeUpdate -> onBeforeUpdate

updated -> onUpdated

beforeDestroy -> onBeforeUnmount

destroyed -> onUnmounted

errorCaptured -> onErrorCaptured

如果要想在页面中使用生命周期函数,以往vue2的操作是直接在页面中写入生命周期,而vue3是需要去引用的,这就是为什么3能够将代码压缩到更低的原因


讯享网

vue3移除了配置文件目录,config 和 build 文件夹,移除了 static 文件夹,新增 public 文件夹,并且 index.html 移动到 public 中,在 src 文件夹中新增了 views 文件夹,用于分类视图组件和公共组件

在 Vue3 中,全局和内部 API 都经过了重构,并考虑到了 tree-shaking 的支持。因此,全局 API现在只能作为 ES 模块构建的命名导出进行访问。

入口文件

Proxy 相比于 defineProperty 的优势

Object.defineProperty() 的问题主要有三个:

    讯享网<li>不能监听数组的变化</li> <li>必须遍历对象的每个属性</li> <li>必须深层遍历嵌套的对象<br /> </li> 

Proxy 在 ES2015 规范中被正式加入,它有以下几个特点:

    <li>针对对象:针对整个对象,而不是对象的某个属性,所以也就不需要对 keys 进行遍历。这解决了上述 Object.defineProperty() 第二个问题</li> <li>支持数组:Proxy 不需要对数组的方法进行重载,省去了众多 hack,减少代码量等于减少了维护成本,而且标准的就是最好的。</li> 

除了上述两点之外,Proxy 还拥有以下优势:

    讯享网<li>Proxy 的第二个参数可以有 13 种拦截方法,这比起 Object.defineProperty() 要更加丰富</li> <li>Proxy 作为新标准受到浏览器厂商的重点关注和性能优化,相比之下 Object.defineProperty() 是一个已有的老方法。</li> 

以上就是Vue3对比Vue2的优点总结的详细内容,更多关于Vue3对比Vue2的优点的资料请关注脚本之家其它相关文章!

小讯
上一篇 2025-06-07 12:34
下一篇 2025-04-14 09:43

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/205438.html