当前位置:网站首页 > Vue.js开发 > 正文

vue2和vue3区别(vue2和vue3区别diff)



       用组合式api替换选项式ap,旧的选项式api在代码里分割了不同的属性:data,computed,methods等;新得组合式api能让我们使用方法来分割,相比于旧的API使用属性来分组,这样代码会更加简便和整洁。

  • 因为改成了组合式api所以没有了this
  • 生命周期没有create,setup等同于create,卸载改成了unmount
  • vue3中v-if高于v-for的优先级
  • 根实例的创建从new app改成了createApp方法
  • 一些全局注册,比如mixin,注册全局组件,use改成了用app实例调用,而不是vue类调用
  • 新增了传送门teleport组件
  • template模版可以不包在一个根div里

       vue2的双向数据绑定是利用了es5 的一个API Object.definepropert() 对数据进行劫持 结合发布订阅模式来实现的。vue3中使用了es6的proxyAPI对数据进行处理。

       相比与vue2,使用proxy API 优势有:defineProperty只能监听某个属性,不能对全对象进行监听;可以省去for in 、闭包等内容来提升效率(直接绑定整个对象即可);可以监听数组,不用再去单独的对数组做特异性操作,vue3可以检测到数组内部数据的变化。

       注意:vue3并不是完全的抛弃了defineProperty,通过reactive定义的响应式数据使用proxy包装出来,而ref还是用的defineProperty去给一个空对象,定义了一个value属性来做的响应式。

       组合式api的写法下,源码改成了函数式编程,方便按需引入,因为tree-shaking功能必须配合按需引入写法。所以vue3更好的配合tree-shaking能让打包体积更小。

       性能优化,增加了静态节点标记。会标记静态节点,不对静态节点进行比对。从而增加效率。

具体示例如下:

       vue3不推荐使用mixin进行复用逻辑提取,而是推荐使用hook。

       vue2中组件中传递一个value,监听 change/input事件;vue3通过modelValue传递值,监听的是update:modelValue事件

vue2     -----------------------------    vue3
beforeCreate                         ->   setup()
Created                                 ->   setup()
beforeMount                          ->   onBeforeMount
mounted                                ->    onMounted
beforeUpdate                        ->    onBeforeUpdate
updated                                 ->    onUpdated
beforeDestroyed                    ->    onBeforeUnmount
destroyed                              ->     onUnmounted
activated                                ->     onActivated
deactivated                            ->     onDeactivated
 










  1. setup()函数接收两个参数:props、context(包含attrs、slots、emit)
  2. setup函数是处于生命周期beforeCreated和created俩个钩子函数之前
  3. 执行setup时,组件实例尚未被创建(在setup()内部,this不会是该活跃实例得引用,即不指向vue实例,Vue为了避免我们错误得使用,直接将setup函数中得this修改成了undefined)
  4. 与模板一起使用时,需要返回一个对象
  5. 因为setup函数中,props是响应式得,当传入新的prop时,它将会被更新,所以不能使用es6解构,因为它会消除prop得响应性,如需解构prop,可以通过使用setup函数中得toRefs来完成此操作。
  6. 父传子,用props,子传父用事件 Emitting Events。在vue2中,会调用this$emit然后传入事件名和对象;在vue3中得setup()中得第二个参数content对象中就有emit,那么我们只要在setup()接收第二个参数中使用分解对象法取出emit就可以在setup方法中随意使用了。
  7. 在setup()内使用响应式数据时,需要通过 .value 获取
 
  

到此这篇vue2和vue3区别(vue2和vue3区别diff)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 安装vue报错(vuex安装 报错)2025-10-06 19:09:09
  • cjson库内存泄露(console.log内存泄露)2025-10-06 19:09:09
  • vue 插槽传值(vue插槽怎么传值)2025-10-06 19:09:09
  • plsql10.0.3.1701注册码(plsql14注册码)2025-10-06 19:09:09
  • pcie5.0电源和ATX3.0(pcie3.0和sata)2025-10-06 19:09:09
  • vue2转vue3(vue2转vue3很痛苦)2025-10-06 19:09:09
  • pcie5.0有什么用(pcie5.0什么时候上市)2025-10-06 19:09:09
  • pcie 4.0固态硬盘(pcie 4.0固态硬盘插到pcie3.0)2025-10-06 19:09:09
  • js深度拷贝和浅拷贝(js深拷贝和浅拷贝的方法)2025-10-06 19:09:09
  • ettercap下载和安装(ettercap 0.8.3教程)2025-10-06 19:09:09
  • 全屏图片