深入解析Vue3:从入门到实战(详细版)
文章目录
- 前言
- 一、Vue3简介
- 官网地址
- 主要特点
- 二、安装与创建Vue3项目
- 使用Vue CLI创建项目
- 使用Vite创建项目
- 三、Composition API详解
- Setup函数
- ref与Reactive
- 生命周期钩子
- 计算属性和监听器
- 四、新特性与优化
- 响应式系统
- 更好的TypeScript支持
- 类型定义
- 类型推断
- 新组件
- 全局API重构
- 更好的测试支持
- 五、实战案例
- 结语
前言
Vue.js 是一款用于构建用户界面的渐进式JavaScript框架。自Vue2推出以来,其简洁优雅的API设计、轻量级的特性以及出色的性能表现赢得了广大开发者的好评。随着前端技术的快速发展,Vue3应运而生,带来了众多令人兴奋的新特性和改进。本文旨在全面介绍Vue3的核心概念、新特性以及如何将其应用于实际项目中。
一、Vue3简介
Vue3是Vue.js框架的第三个主要版本,于2020年9月18日正式发布。相较于Vue2,Vue3在多个方面实现了显著的提升。
官网地址
- https://cn.vuejs.org/
主要特点
- 性能优化:Vue3利用现代JavaScript特性(如Proxy),在保持现有API的同时,提升了应用的运行效率。
- 体积减小:通过更精细的模块化设计和Tree Shaking支持,Vue3的初始加载时间更快,最终包体积更小。
- TypeScript支持:Vue3原生支持TypeScript,使得类型安全性和开发体验得到了极大的提升。
- Composition API:Vue3引入了一种全新的API设计模式——Composition API,它允许开发者更灵活地组织和复用逻辑代码。
- 更好的测试支持:Vue3提供了一系列工具和库,使得单元测试和端到端测试更加便捷。
二、安装与创建Vue3项目
使用Vue CLI创建项目
Vue CLI 是Vue.js的官方脚手架工具,可以帮助开发者快速搭建项目。要创建一个Vue3项目,首先需要确保已安装最新版本的Vue CLI。可以通过以下命令检查或安装:
# 检查Vue CLI版本
vue --version# 如果版本低于4.5.0,请更新
npm install -g @vue/cli
然后,使用Vue CLI创建一个新的Vue3项目:
vue create my-vue3-project
在创建过程中,选择Vue 3预设或者手动选择特性,确保选择了Vue 3版本。
使用Vite创建项目
Vite 是由Vue.js作者尤雨溪开发的一款现代化的前端构建工具,它利用浏览器原生的ES模块导入功能,实现了快速启动和按需编译,非常适合Vue3项目。创建一个基于Vite的Vue3项目,只需几行命令:
npm init vite@latest my-vue3-project --template vue
cd my-vue3-project
npm install
npm run dev
三、Composition API详解
Setup函数
Composition API的核心是setup函数,它替代了Vue2中的data、methods、computed等选项。setup函数在组件实例初始化之前调用,可以接收组件的props和context作为参数,并且必须返回一个对象,该对象中的属性和方法可以在模板中直接使用。
export default {props: {message: String},setup(props, context) {// 组件逻辑...return {// 需要在模板中使用的属性和方法}}
}
ref与Reactive
Vue3中提供了两种方式来创建响应式数据:ref和reactive。
- ref:用于创建一个响应式的引用对象,可以用来包裹任何类型的值。在模板中使用时,不需要.value后缀。
- reactive:用于创建一个深层响应式的对象。对于对象类型的数据,推荐使用reactive。
import { ref, reactive } from 'vue'// 使用ref
let count = ref(0)// 使用reactive
let state = reactive({name: 'Vue',count: 0
})// 在setup函数中使用
export default {setup() {let count = ref(0)let state = reactive({name: 'Vue',count: 0})function increment() {count.value++state.count++}return {count,state,increment}}
}
生命周期钩子
Vue3中的生命周期钩子名称有所变化,但它们的功能和使用方式与Vue2相似。Vue3提供了新的生命周期钩子函数,如onMounted、onUnmounted等。
import { onMounted, onUnmounted } from 'vue'export default {setup() {onMounted(() => {console.log('组件已挂载')})onUnmounted(() => {console.log('组件已卸载')})// ...}
}
计算属性和监听器
Vue3中计算属性和监听器也有了新的API。
- 计算属性:使用computed函数创建。
- 监听器:使用watch函数创建。
import { ref, computed, watch } from 'vue'export default {setup() {let count = ref(0)// 计算属性let doubleCount = computed(() => count.value * 2)// 监听器watch(count, (newVal, oldVal) => {console.log(`count changed from ${oldVal} to ${newVal}`)})return {count,doubleCount}}
}
四、新特性与优化
响应式系统
Vue3的响应式系统基于ES6的Proxy对象,相比Vue2的Object.defineProperty方法,它能够更高效地处理对象属性的添加和删除操作,同时避免了数组索引更改不触发更新的问题。
更好的TypeScript支持
Vue3提供了更好的TypeScript支持,包括类型推断和类型检查,这使得使用TypeScript开发Vue应用变得更加容易。
类型定义
Vue3提供了详细的类型定义文件,可以通过安装@vue/runtime-dom来获取这些类型定义。
npm install @vue/runtime-dom
类型推断
Vue3中的ref和reactive函数会自动推断类型。
import { ref, reactive } from 'vue'let count = ref(0) // count的类型为Ref<number>
let state = reactive({ name: 'Vue' }) // state的类型为{ name: string }
新组件
Vue3引入了几个新的内置组件,如<Fragment>
、<Teleport>
和<Suspense>
,它们分别解决了多根节点、DOM结构优化和异步组件加载的问题。
<Fragment>
:允许在一个组件中返回多个根节点。<template><Fragment><h1>Title</h1><p>Content</p></Fragment> </template>
<Teleport>
:允许将模态框或其他组件的内容渲染到DOM树的任意位置。<template><button @click="openModal">Open Modal</button><Teleport to="body"><div v-if="isModalOpen" class="modal"><p>This is a modal</p><button @click="closeModal">Close</button></div></Teleport> </template><script> import { ref } from 'vue'export default { setup() {let isModalOpen = ref(false)function openModal() {isModalOpen.value = true} function closeModal() {isModalOpen.value = false}return {isModalOpen,openModal,closeModal}} } </script>
<Suspense>
:用于处理异步依赖,等待所有异步操作完成后再渲染组件。<template><Suspense><template #default><AsyncComponent /></template><template #fallback><div>Loading...</div></template></Suspense> </template><script> import { defineAsyncComponent } from 'vue'const AsyncComponent = defineAsyncComponent(() => import('./components/MyComponent.vue'))export default {components: {AsyncComponent} } </script>
全局API重构
Vue3对全局API进行了重构,将许多全局方法和属性移动到了app.config.globalProperties
中,减少了全局污染,提高了模块化的程度。
import { createApp } from 'vue'
import App from './App.vue'const app = createApp(App)// 添加全局属性
app.config.globalProperties.$myGlobalMethod = () => {console.log('This is a global method')
}// 添加全局指令
app.directive('focus', {mounted(el) {el.focus()}
})app.mount('#app')
更好的测试支持
Vue3提供了一系列工具和库,使得单元测试和端到端测试更加便捷。
- 单元测试:使用Vue Test Utils进行单元测试。
npm install @vue/test-utils @vue/vue3-jest jest
import { mount } from '@vue/test-utils' import MyComponent from '@/components/MyComponent.vue'describe('MyComponent.vue', () => {it('renders correctly', () => {const wrapper = mount(MyComponent, {props: {message: 'Hello, Vue3!'}})expect(wrapper.text()).toContain('Hello, Vue3!')}) })
- 端到端测试:使用Cypress进行端到端测试。
npm install cypress
describe('My App', () => {it('displays the correct title', () => {cy.visit('/')cy.get('h1').should('contain', 'Welcome to Vue3')}) })
五、实战案例
示例项目:Todo List
我们将通过一个简单的Todo List应用来展示Vue3的一些核心特性和新特性。
项目结构
my-todo-app/
├── public/
│ └── index.html
├── src/
│ ├── assets/
│ ├── components/
│ │ └── TodoList.vue
│ ├── App.vue
│ └── main.js
├── package.json
└── vite.config.js
安装依赖
npm install vue
创建主应用文件
src/main.js
import { createApp } from 'vue'
import App from './App.vue'createApp(App).mount('#app')
创建App组件
src/App.vue
<template><div id="app"><h1>Todo List</h1><TodoList /></div>
</template><script>
import TodoList from './components/TodoList.vue'export default {components: {TodoList}
}
</script>
创建TodoList组件
src/components/TodoList.vue
<template><div><input v-model="newTodo" @keyup.enter="addTodo" placeholder="Add a new todo" /><ul><li v-for="(todo, index) in todos" :key="index">{{ todo }}<button @click="removeTodo(index)">Remove</button></li></ul></div>
</template><script>
import { ref } from 'vue'export default {setup() {let newTodo = ref('')let todos = ref([])function addTodo() {if (newTodo.value.trim()) {todos.value.push(newTodo.value)newTodo.value = ''}}function removeTodo(index) {todos.value.splice(index, 1)}return {newTodo,todos,addTodo,removeTodo}}
}
</script>
结语
Vue3不仅继承了Vue2的优点,而且通过引入Composition API、优化响应式系统、增强TypeScript支持等一系列创新,为开发者提供了更加灵活、高效的开发体验。无论是对于新手还是经验丰富的开发者,Vue3都值得尝试和深入学习。希望本文能够帮助你更好地理解和掌握Vue3的核心概念和技术要点,开启你的Vue3之旅。
相关文章:

深入解析Vue3:从入门到实战(详细版)
文章目录 前言一、Vue3简介官网地址主要特点 二、安装与创建Vue3项目使用Vue CLI创建项目使用Vite创建项目 三、Composition API详解Setup函数ref与Reactive生命周期钩子计算属性和监听器 四、新特性与优化响应式系统更好的TypeScript支持类型定义类型推断新组件全局API重构更好…...

Pr 视频效果:ASC CDL
视频效果/颜色校正/ASC CDL Color Correction/ASC CDL ASC CDL ASC CDL效果通过对红、绿、蓝三个原色通道的独立调整,实现对图像色彩的精确控制。在此基础上,还可用于调整处理后图像的整体饱和度。 ◆ ◆ ◆ 效果选项说明 斜率 Slope、偏移 Offset和功…...

C++ --- Socket套接字的使用
目录 一.什么是Socket套接字? 二.Socket的使用: 前置步骤: 为什么要加入 WSAStartup 和 WSACleanup ? 1.创建Socket: 2.绑定Socket: 3.服务端监听连接请求: 4.服务端接受客户端连接&…...

MG协议转换器:制氢行业的数字桥梁
在新能源产业蓬勃发展的今天,制氢行业正迎来前所未有的发展机遇。作为清洁能源的重要组成部分,氢气的生产与利用不仅关乎环境保护,更是推动能源结构转型的关键一环。然而,在制氢行业的数字化转型进程中,数据的传输与处…...

人工智能技术的未来:变革生活与工作的潜力
随着人工智能(AI)技术的不断发展,我们已经见证了其在各行各业的巨大变革。无论是在医疗、商业还是日常生活中,AI都正在悄然改变着我们的工作方式和生活方式。未来,人工智能的应用前景广阔,它将继续深入我们…...

D60【python 接口自动化学习】- python基础之数据库
day60 数据库定义 学习日期:20241106 学习目标:MySQL数据库-- 128:数据库定义 学习笔记: 无处不在的数据库 数据库如何存储数据 数据库管理系统(数据库软件) 数据库和SQL的关系 总结 数据库就是指数据…...

零基础大龄程序员如何转型AI大模型,系统学习路径与资源推荐!!
前言 随着科技的飞速发展,AI大模型浪潮席卷全球,相关岗位炙手可热。在这个背景下,许多大龄程序员开始思考如何转型,以适应时代的变化。结合自身编程基础,大龄程序员可以学习机器学习、深度学习算法,投身于…...

vue3+vant实现使用van-picker实现三级级联菜单展示(含递归遍历)
1、递归遍历三级展示,禁用自动弹起软键盘、设置文档自动换行避免过长文本省略号展示 <div class"text_div"><van-fieldclass"span_text":center"true"v-model"jobLevelCodeText"is-linklabel"任职岗位"…...

oracle-函数-grouping sets(x1,x2,x3...)的妙用
GROUPING SETS 允许你为多个列组合生成分组汇总。它类似于多个 GROUP BY 子句的 UNION ALL 操作,但更加简洁和高效 首先:创建表及接入测试数据 create table students (id number(15,0), area varchar2(10), stu_type varchar2(2), score number(20,2))…...

人工智能在医疗病例诊断中的应用与展望
人工智能在医疗病例诊断中的应用与展望 摘要: 本文探讨了人工智能在医疗病例诊断中的卓越应用、显著优势、面临的挑战及应对策略,以及未来展望。人工智能在医学影像诊断、病理诊断和辅助临床诊断方面展现出巨大潜力,为医学研究和临床治疗带来…...

OceanBase 安装使用详细说明
OceanBase 安装使用详细说明 一、系统环境要求二、安装OceanBase环境方案一:在线下载并安装all-in-one安装包方案二:离线安装all-in-one安装包安装前的准备工作三、配置OceanBase集群编辑配置文件部署和启动集群连接到集群集群状态和管理四、创建业务租户和数据库创建用户并赋…...

CI_CD
什么是CI/CD 在前端开发中,CI/CD 是 Continuous Integration(持续集成)和 Continuous Deployment/Continuous Delivery(持续部署/持续交付)的简称。它是一种软件开发实践,自动化了应用的构建、测试和发布过…...

Linux -- 初识线程
目录 线程的初步认识 为什么需要线程 怎么让代码分成多个执行流并发执行呢? 管理线程 线程的初步认识 线程是进程内部的一个执行分支,线程是CPU调度的基本单位。 在Linux操作系统中,线程是程序执行流的最小单位。一个进程可以包含多个线…...

Uniapp底部导航栏设置(附带PS填充图标教程)
首先需要注册和登录ifconfont官网,然后创建项目添加需要的图标 创建和添加图标库请参考:Uniapp在Vue环境中引入iconfont图标库(详细教程) 打开iconfont官网,找到之前添加的图标库,下载png图片 如果需要的…...

单智能体carla强化学习实战工程介绍
有三个工程: Ray_Carla: 因为有的论文用多进程训练强化学习,包括ray分布式框架等,这里直接放了一个ray框架的示例代码,是用sac搭建的,obs没用图像,是数值状态向量值(速度那些)。 …...

潮玩宇宙方块兽系统开发:可定制UI与多种游戏内嵌助力个性化体验
潮玩宇宙方块兽系统开发正在推动潮玩与游戏的融合,通过个性化的UI设计和多游戏内嵌模式,为用户带来了独一无二的体验。本文将从可定制UI、多游戏内嵌功能以及系统实现等方面入手,探讨如何构建一个极具吸引力的潮玩宇宙方块兽系统。 一、可定制…...

什么是低代码?3000字低代码超全解读!
现在这个时代企业面对的挑战越来越复杂,尤其在软件开发和应用交付方面,因为传统开发过程复杂且费时,企业很难从传统的软件开发方式中迅速响应市场变化从而获利。 而低代码(Low-Code)平台的出现为企业提供了一种更加快…...

雷池社区版7.1新版本自定义NGINX配置分析
简单介绍雷池,是一款简单好用, 效果突出的 Web 应用防火墙(WAF),可以保护 Web 服务不受黑客攻击。 雷池通过阻断流向 Web 服务的恶意 HTTP 流量来保护 Web 服务。雷池作为反向代理接入网络,通过在 Web 服务前部署雷池,可在 Web 服…...

[SAP ABAP] 面向对象程序设计-类和对象
面向对象开发的特点:封装、继承和多态 什么是类和对象? 类(CLASS)是创建对象的模板,对象(OBJECT)是类的实例 一个类可以创建多个对象 类 > 类型 对象 > 个体 在ABAP语言中,定义一个类,需要包含定义(defin…...

『大模型笔记』IBM技术团队:什么是智能体型RAG!
『大模型笔记』IBM技术团队:什么是智能体型RAG! 文章目录 一. 『大模型笔记』IBM技术团队:什么是智能体型RAG!二. 参考文献一. 『大模型笔记』IBM技术团队:什么是智能体型RAG! ✅检索增强生成(RAG)是一种结合检索和生成能力的技术,通过从向量数据库检索相关信息作为上…...

WPF 中 NavigationWindow 与 Page 的继承关系解析
官网解析: NavigationWindow 类 | Page 类 public class BaseWindow: NavigationWindow{} public partial class CountPage : Page{} 都是创建的WPF界面有什么区别? 在 WPF(Windows Presentation Foundation)开发中&#…...

WebRTC基础理论和通话原理
WebRTC理论知识 1.什么是WebRTC? WebRTC(Web RealTime Communication)是 Google于2010以6829万美元从 Global IP Solutions 公司购买,并 于2011年将其开源,旨在建立一个互联网浏览器间的实时通信的平台,让 WebRTC技术…...

NPU 可不可以代替 GPU
结论 先说结论,GPU分为可以做图形处理的传统意义上的真GPU,做HPC计算的GPGPU和做AI加速计算的GPGPU,所以下面分别说: 对于做图形处理的GPU,这个就和NPU 一样,属于DSA,没有替代性。当然…...

Vue3版本的uniapp项目运行至鸿蒙系统
新建Vue3版本的uniapp项目 注意,先将HbuilderX升级至最新版本,这样才支持鸿蒙系统的调试与运行; 按照如下图片点击,快速升级皆可。 通过HbuilderX创建 官方文档指导链接 点击HbuilderX中左上角文件->新建->项目 创建vue3…...

部署stable-diffusion3.5 大模型,文生图
UI 使用推荐的ComfyUI,GitHub 地址,huggingface 需要注册登录,需要下载的文件下面有说明 Dockerfile 文件如下: FROM nvidia/cuda:12.4.0-base-ubuntu22.04 RUN apt-get update && apt-get install python3 pip git --n…...

数据采集之selenium模拟登录
使用Cookijar完成模拟登录 本博文爬取实例为内部网站,请sduter使用本人账号替换*********(学号),***(姓名)进行登录 from selenium import webdriver from selenium.webdriver.common.by import By from…...

机器学习中的两种主要思路:数据驱动与模型驱动
在机器学习的研究和应用中,如何从数据中提取有价值的信息并做出准确预测,是推动该领域发展的核心问题之一。在这个过程中,机器学习方法主要依赖于两种主要的思路:数据驱动与模型驱动。这两种思路在不同的应用场景中发挥着至关重要…...

【计算机网络】TCP协议面试常考(一)
三次握手和四次挥手是TCP协议中非常重要的机制,它们在多种情况下确保了网络通信的可靠性和安全性。以下是这些机制发挥作用的一些关键场景: 三次握手的必要性: 同步序列号: 三次握手确保了双方的初始序列号(ISN&#…...

C#/.NET/.NET Core学习路线集合,学习不迷路!
前言 C#、.NET、.NET Core、WPF、WinForm、Unity等相关技术的学习、工作路线集合(持续更新)!!! 全面的C#/.NET/.NET Core学习、工作、面试指南:https://github.com/YSGStudyHards/DotNetGuide C#/.NET/.N…...

使用哈希表做计数排序js
function hashSort(arr) {// 创建一个哈希表(对象),统计每个数字出现的次数let hashMap {};arr.forEach(num > {if (hashMap[num]) {hashMap[num] 1;} else {hashMap[num] 1;}});// 根据哈希表的键值对构建排序后的数组let sortedArr …...