千家信息网

Vue3和Vue2比对有什么不同

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍"Vue3和Vue2比对有什么不同"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Vue3和Vue2比对有什么不同"文章能帮助大家解决问题。性能
千家信息网最后更新 2025年01月19日Vue3和Vue2比对有什么不同

这篇文章主要介绍"Vue3和Vue2比对有什么不同"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Vue3和Vue2比对有什么不同"文章能帮助大家解决问题。

性能

Vue 2.6.10 最小化压缩 22.8kB

Vue 3 最小化压缩约为 10KB

全局API

vue2:

Vue核心使用什么功能,它们最终都会出现在生产代码中,因为Vue实例被导出为单个对象

vue3:

按需导出,只导出使用到的API并删除未使用的代码。所以以前的全局API现在只能通过命名的导出才能使用。

示例

vue2

// Vue 2.x - whole ——Vue—— object is bundled for production

import Vue from 'vue'

Vue.nextTick(() => {})

const obj = Vue.observable({})

vue3

// Vue 3.x - only imported properties are bundled

import { nextTick, observable } from 'vue'

nextTick(() => {})

const obj = observable({})

属性赋值

vue2 基于的Object.defineProperty, 我们需要使用Vue.set,Vue.delete 来设值属性值,触发属性值的变化。

vue3 使用JS Proxies, 直接对属性进行赋值,就可以触发属性值变化。

并且vue3的这一改进,可以更快触发属性值变化,性能比vue2 大约快2倍。

示例

// Adding a new property to reacitve object in Vue 2.x

Vue.set(this.myObject, key, value)

// Adding a new property to reactive object in Vue 3

this.myObject[key] = value

重新渲染组件识别

Vue 3中新增一个新的生命周期挂钩-renderTriggered, 我们renderTriggered可以使用它来跟踪和消除不必要的组件重新渲染, 这对在运行时组件的性能优化有非常有用。

示例

const Component = {

// other properties

renderTriggered (event) {

console.log(——Re-render of —— + this.$options.name + —— component——, event)

}

}

关于"Vue3和Vue2比对有什么不同"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

0