Vue3 和Vue2的区别,以及钩子函数的使用

2024-01-21

Vue.js 3 和 Vue.js 2 是两个主要版本的流行前端框架,它们之间有很多区别,包括性能优化、新特性和改进的API等。以下是一些Vue 3与Vue 2之间的主要区别,以及一些示例代码来说明这些差异。

1. 性能优化

  • 响应式系统 : Vue 3 使用了 Proxy 来实现响应式系统,相比 Vue 2 的 Object.defineProperty,它提供了更好的性能,并且能够检测到对象属性的添加和删除。
  • 虚拟DOM : Vue 3 对虚拟DOM进行了重写,以利用现代JavaScript引擎的优化。

2. 组合式API (Composition API)

Vue 3 引入了组合式API,这是一种新的方式来组织和重用代码逻辑。与Vue 2的选项API(Options API)相比,组合式API提供了更大的灵活性和更好的代码组织。

// Vue 2 (Options API)
export default {
  data() {
    return {
      count: 0
    };
  },
  methods: {
    increment() {
      this.count++;
    }
  }
};

// Vue 3 (Composition API)
import { ref } from 'vue';

export default {
  setup() {
    const count = ref(0);

    function increment() {
      count.value++;
    }

    return {
      count,
      increment
    };
  }
};

3. 片段特性

Vue 3 允许组件有多个根节点,而Vue 2每个组件只能有一个根节点。

<!-- Vue 2 (单个根节点) -->
<template>
  <div>
    <header></header>
    <main></main>
    <footer></footer>
  </div>
</template>

<!-- Vue 3 (多个根节点) -->
<template>
  <header></header>
  <main></main>
  <footer></footer>
</template>

4. Teleport 特性

Vue 3 引入了 Teleport 特性,允许您将组件的子节点“传送”到DOM中的其他位置。

<!-- 使用 Teleport 将模态框传送到 body 元素的末尾 -->
<template>
  <button @click="showModal = true">显示模态框</button>
  <teleport to="body">
    <div class="modal" v-if="showModal">
      我是模态框内容
    </div>
  </teleport>
</template>

5. 其他改进

  • 更好的错误处理 : Vue 3 提供了更详细的错误信息和堆栈跟踪。
  • 更小的体积 : Vue 3 的运行时体积比 Vue 2 更小。
  • 更好的TypeScript支持 : Vue 3 的源代码是用TypeScript编写的,提供了更好的类型支持。

请注意,上面的 Teleport 特性实际上是在 Vue 3 的一个库 Vue Router 中提供的,而不是 Vue 核心库的一部分。我提供这个示例是为了展示 Vue 3 生态系统中的一些新特性,但请确保在实际项目中正确使用相关库和API。

总的来说,Vue 3 提供了很多改进和新特性,使得开发体验更加流畅,代码更加可维护。然而,由于这些变化,从 Vue 2 迁移到 Vue 3 可能需要一些时间和努力。

钩子函数

Vue.js 2 和 Vue.js 3 都提供了一套生命周期钩子函数,这些钩子允许开发者在组件的不同阶段执行代码。不过,Vue 3 引入了 Composition API,其中包含了新的钩子函数 setup ,这个钩子在 Vue 2 中是不存在的。此外,Vue 3 也对部分生命周期钩子的名称进行了调整,以更好地反映其用途和触发时机。

Vue 2 的生命周期钩子

  • beforeCreate : 实例初始化之后,数据观测和事件/监听事件的配置之前被调用。
  • created : 实例创建完成后被立即调用。在这一步,实例已完成以下的配置:数据观测、属性和方法的运算、 watch/event 事件回调。然而,挂载阶段还没开始。
  • beforeMount : 在挂载开始之前被调用,相关的 render 函数首次被调用。
  • mounted : 实例被挂载后调用,其中 el 被新创建的 vm.$el 替换。
  • beforeUpdate : 数据更新时调用,发生在虚拟DOM打补丁之前。
  • updated : 实例更新完毕之后调用。
  • beforeDestroy : 实例销毁之前调用。在这一步,实例仍然完全可用。
  • destroyed : 实例销毁后调用。

Vue 3 的生命周期钩子

Vue 3 保留了大部分 Vue 2 中的生命周期钩子,但是有两个钩子的名称发生了变化,同时也引入了新的 setup 钩子:

  • beforeMount mounted : 功能和用法与 Vue 2 中相同。
  • beforeUpdate updated : 功能和用法与 Vue 2 中相同。
  • beforeUnmount : 替换了 Vue 2 中的 beforeDestroy ,在组件卸载前调用。
  • unmounted : 替换了 Vue 2 中的 destroyed ,在组件卸载后调用。
  • setup : Vue 3 新增的钩子,它是使用 Composition API 的入口点。 setup 钩子在 beforeCreate created 钩子之前调用,并且不接受 this 上下文,因为它是组件实例被创建之前调用的。

Vue 3 中的 setup 钩子与 Composition API

在 Vue 3 中,你可以使用 setup 钩子来组织和共享组件的逻辑代码。 setup 钩子函数接收两个参数: props context

import { ref } from 'vue';

export default {
  props: {
    propName: String,
  },
  setup(props, context) {
    const state = ref(0);

    function increment() {
      state.value++;
    }

    return {
      state,
      increment,
    };
  },
};

在上面的例子中, state increment 函数是组件的逻辑部分,它们被定义在 setup 钩子中,并最后返回给模板使用。 props 是传入组件的属性,而 context 提供了一些额外的功能,比如访问 attrs、slots 和 emit 函数。

总之,Vue 3 中的生命周期钩子大部分与 Vue 2 相同,但是引入了一个新的 setup 钩子来支持 Composition API,并且对一些钩子的名称进行了调整以更好地描述其用途。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Vue3 和Vue2的区别,以及钩子函数的使用 的相关文章

随机推荐

  • 界面控件DevExpress WPF属性网格 - 让应用轻松显示编辑各种属性事件

    DevExpress WPF Property Grid 属性网格 灵感来自于Visual Studio Visual Studio启发的属性窗口 对象检查器 让在WPF应用程序显示和编辑任何对象的属性和事件变得更容易 P S DevExp
  • HTML概述、基本语法(表格整理、标签、基本结构)

    一 HTML概述 HTML指的是超文本标记语言 超文本 是指页面内可以包含图片 链接 声音 视频等内容 标记 标签 通过标记符号来告诉浏览器页面该如何显示 我们可以打开浏览器 右击页面 点击 查看网页源代码 来方便了解HTML标签通过浏览器
  • 游戏开发中常见系统梳理之背包系统的实现一

    游戏中几乎都存在大大小小的背包系统 接下来我将讲述背包系统具体是如何实现的 完整源码 以下是使用unity NGUI实现 使用txt配置的方法 后续更新UGUI Json实现的背包系统敬请期待 背包中的物品我们常常将其制作成预设体 通过改变
  • 揭秘看不见人的“黑灯工厂”

    你知道吗 未来工厂不需要人也能24小时运转 未来机器能自己配合的天衣无缝 未来工厂连一点灰尘都进不去 未来自研的智能化设备甚至几秒就能生产出一部手机 千万不要惊讶 其实这样的工厂已经在我们的身边 很可能你在元旦买到的一件衣服 一部手机就是
  • 点击存储到固定时间清除存储

    这段代码 无意间想到的 随便写了下来 运行 根据点击之后传递一个参数 将他存入本地存储 方便测试为10秒 10秒后触发下一个事件 清除本地存储 结束
  • ​LeetCode解法汇总83. 删除排序链表中的重复元素

    目录链接 力扣编程题 解法汇总 分享 记录 CSDN博客 GitHub同步刷题项目 https github com September26 java algorithms 原题链接 力扣 LeetCode 描述 给定一个已排序的链表的头
  • 界面组件DevExpress ASP.NET Core v23.2 - 拥有全新的主题样式

    DevExpress ASP NET Core Controls使用强大的混合方法 结合现代企业Web开发工具所期望的所有功能 该套件通过ASP NET Razor标记和服务器端ASP NET Core Web API的生产力和简便性 提供
  • 【wrf-python】将modis土地利用分类按照wrf可识别的格式制作静态数据集

    下载modis数据后 可以按照gdal translate of ENVI co INTERLEAVE BSQ xxx1 tif output2001 bin命令处理tif数据 也可以按照下面的python语句处理tif数据 import
  • Creator AIGC插件!一句话生成人脸

    近几个月以来 AIGC 一路高歌猛进 让我们见证了一场行业革命 然而 AIGC 在 3D 资产领域却仍是业内的难题 少有突破 小编今天给大家推荐一个 3D 角色 AIGC 利器 ChatAvatar 它可以算是 3D AIGC 领域的一匹黑
  • 【gee】下载modis土地利用类型

    var china ee FeatureCollection projects assets china boundary var lc dataset ee ImageCollection MODIS 061 MCD12Q1 filter
  • ​LeetCode解法汇总82. 删除排序链表中的重复元素 II

    目录链接 力扣编程题 解法汇总 分享 记录 CSDN博客 GitHub同步刷题项目 https github com September26 java algorithms 原题链接 力扣 LeetCode 描述 给定一个已排序的链表的头
  • 「Java开发指南」MyEclipse如何支持Spring Scaffolding?(一)

    MyEclipse v2023 1 2离线版下载 1 使用Spring的Scaffolding应用程序 支持Spring的 MyEclipse 目标之一是帮助开发人员从零开始编写更少的代码 并更广泛地使用代码生成 MyEclipse提供了丰
  • 盲猜你不懂H5架构和原生架构的区别

    2024软件测试面试刷题 这个小程序 永久刷题 靠它快速找到工作了 刷题APP的天花板 CSDN博客 文章浏览阅读2 3k次 点赞85次 收藏11次 你知不知道有这么一个软件测试面试的刷题小程序 里面包含了面试常问的软件测试基础题 web自
  • qt.qpa.plugin: Could not find the Qt platform plugin “windows“ in ““

    系统环境 Win10家庭中文版 Qt 5 12 9 链接了一些64位的第三方库 程序编译完运行后出现 qt qpa plugin Could not find the Qt platform plugin windows in 弹窗如下 网
  • Python自动化测试 | 如何使用Robot Framework进行自动化测试?

    2024软件测试面试刷题 这个小程序 永久刷题 靠它快速找到工作了 刷题APP的天花板 CSDN博客 文章浏览阅读2 3k次 点赞85次 收藏11次 你知不知道有这么一个软件测试面试的刷题小程序 里面包含了面试常问的软件测试基础题 web自
  • 跨平台UI自动化框架:Airtest,游戏开发和应用测试的利器

    2024软件测试面试刷题 这个小程序 永久刷题 靠它快速找到工作了 刷题APP的天花板 CSDN博客 文章浏览阅读2 3k次 点赞85次 收藏11次 你知不知道有这么一个软件测试面试的刷题小程序 里面包含了面试常问的软件测试基础题 web自
  • 测开和测试平台是否有存在的必要?

    2024软件测试面试刷题 这个小程序 永久刷题 靠它快速找到工作了 刷题APP的天花板 CSDN博客 文章浏览阅读2 3k次 点赞85次 收藏11次 你知不知道有这么一个软件测试面试的刷题小程序 里面包含了面试常问的软件测试基础题 web自
  • 如何写好一个错误报告

    2024软件测试面试刷题 这个小程序 永久刷题 靠它快速找到工作了 刷题APP的天花板 CSDN博客 文章浏览阅读2 3k次 点赞85次 收藏11次 你知不知道有这么一个软件测试面试的刷题小程序 里面包含了面试常问的软件测试基础题 web自
  • 一篇文章带你了解Python常用自动化测试框架——Pytest

    2024软件测试面试刷题 这个小程序 永久刷题 靠它快速找到工作了 刷题APP的天花板 CSDN博客 文章浏览阅读2 3k次 点赞85次 收藏11次 你知不知道有这么一个软件测试面试的刷题小程序 里面包含了面试常问的软件测试基础题 web自
  • Vue3 和Vue2的区别,以及钩子函数的使用

    Vue js 3 和 Vue js 2 是两个主要版本的流行前端框架 它们之间有很多区别 包括性能优化 新特性和改进的API等 以下是一些Vue 3与Vue 2之间的主要区别 以及一些示例代码来说明这些差异 1 性能优化 响应式系统 Vue