1Vue3介绍
Vue 3是Vue.js框架的最新版本,于2020年9月正式发布。它在Vue 2的基础上进行了重大改进和增强,为开发者提供了更好的性能、开发体验和功能。主要体现在以下方面:
- 响应式系统
- Vue 3引入了基于ES6 Proxy的响应式系统,取代了Vue 2中基于Object.defineProperty的实现。这种改变使得Vue 3的响应式系统更强大和灵活,能够捕获更多类型的变更,提供更好的性能,并且支持动态添加和删除属性。
- Composition API
- Vue 3引入了组合式API(Composition API),作为选项式API(Options API)的补充。组合式API允许开发人员以更模块化、更函数式的方式来组织组件逻辑,提高了代码的可维护性和复用性。它通过使用函数来组织代码,而不仅仅依靠选项,从而提供了更灵活、组合性更强的组件开发方式。
- 性能优化
- Vue 3采用了虚拟DOM算法的改进,通过静态提升(Static Nodes Hoisting)和基于模块的编译优化,提供了更好的性能。它具有更高的渲染速度、更小的包大小,以及更好的Tree-shaking支持,使应用程序更高效。
- Teleport组件
- Vue 3引入了Teleport组件,它使得在DOM树中的任何位置渲染组件变得更容易。Teleport组件在处理跨组件层级的弹出窗口、对话框和模态框等场景时非常有用。
- TypeScript支持
- Vue 3更好地集成了TypeScript,并提供了更准确的类型推断和类型检查。这使得在Vue应用程序中使用TypeScript变得更加流畅和安全。
- 全局API重构
- Vue 3对全局API进行了重构,以提高可用性和一致性。例如,全局的Vue.observable()方法现在更名为reactive(),全局的Vue.set()方法更名为app.$set()。
- 其他新特性
- Vue 3还支持组件的多个根节点,这意味着可以在一个组件内返回多个顶级元素,而不必包裹它们在一个额外的容器内。
- 引入了Suspense组件,用于处理异步数据加载和代码拆分,可以在等待异步数据时显示占位符或加载指示器,以提供更好的用户体验。
2 vue3 项目创建
3 vue3 的项目结构
4 语法糖写法
data:image/s3,"s3://crabby-images/dd957/dd957f5c198a9df550d6f1d03380c68541fc5ce8" alt=""
data:image/s3,"s3://crabby-images/8dbcd/8dbcdd4333af2b50d91b76c8942b4d666e7027e8" alt=""
5 reactive和ref函数
举例
bash
<script setup>
import { reactive } from 'vue'
const state = reactive({
count: 0
})
</script>
<template>
<button @click="state.count++">{{state.count}}</button>
</template>
<style scoped lang='less'>
</style>
data:image/s3,"s3://crabby-images/4cb06/4cb06b5708648bd40888cecb7162fc688fe270bb" alt=""
举例
data:image/s3,"s3://crabby-images/c1b95/c1b95f4c8cd2c469633c479dd8cc388913787076" alt=""
6 计算属性
和 Vue2 不同,Vue2 中是选项式API,Vue3 中是组合式API。
data:image/s3,"s3://crabby-images/f9bdc/f9bdc07c189276760851d3041742f4aa357a29bc" alt=""
data:image/s3,"s3://crabby-images/1b9c4/1b9c467a1007263404a0aeaac4383980331511c8" alt=""
7 watch
data:image/s3,"s3://crabby-images/c4748/c474896dfd995274fff329e698675518f8307854" alt=""
举例
data:image/s3,"s3://crabby-images/92ebe/92ebe40950b01582d1e4e9c0488a899e991137e3" alt=""
data:image/s3,"s3://crabby-images/98e14/98e143294adf6efd82d856e9d6c515864f4f7eb6" alt=""
data:image/s3,"s3://crabby-images/bef8c/bef8cfadfbad6dc1b1562e999ce1f60302169e01" alt=""
8 深度监听
data:image/s3,"s3://crabby-images/c9d76/c9d76e747b66a6f417cd3882b8d10e2cb79851df" alt=""
data:image/s3,"s3://crabby-images/add6f/add6f50cee211687607479baa972c61d95dc861d" alt=""
9 vue3生命周期
data:image/s3,"s3://crabby-images/2a685/2a685b1cdd857c9d37906f009c69f38a83058f0e" alt=""
data:image/s3,"s3://crabby-images/42aba/42abaf92bf326e008bd16b3de69c1d6aaf42e612" alt=""
data:image/s3,"s3://crabby-images/44a52/44a52fc7036de79bdc4512c32f70e9f022ca6ba0" alt=""
10 组件间通信
10.1父传子
data:image/s3,"s3://crabby-images/bb028/bb028ccb8a28425f0fcba2f5775bae038707587a" alt=""
10.2 子传父
data:image/s3,"s3://crabby-images/50c50/50c5070b9bb6e82ec4a40b63cac85b0e66c3fd42" alt=""
11 模板引用
data:image/s3,"s3://crabby-images/acf67/acf6756638c6036aec9e239da43159d2f7333e70" alt=""
举例
data:image/s3,"s3://crabby-images/2fe2c/2fe2c7b313a4a0d14a6509be13e6ba064c629eea" alt=""
12 defineExposedata:image/s3,"s3://crabby-images/bbd60/bbd608a802af47bd7eb59b98813dfacab7f00e26" alt=""
13 provide和inject
data:image/s3,"s3://crabby-images/b64ea/b64ea9e3381e393158679dd97a6422a9d671c222" alt=""
data:image/s3,"s3://crabby-images/6867a/6867a6a52b22fe3506f7b26b359abc8533357285" alt=""
data:image/s3,"s3://crabby-images/19cfc/19cfc1d6fe37c99eb900e9fc0f72b5206bb5bd83" alt=""
14 Pinia
之前学了父子组件之间传递数据,通过 属性
及回调函数
的形式来传递。但是如果涉及到多级组件嵌套,各个组件之间传递数据会非常麻烦。尤其是遇到没有父子关系的组件,在其间传递数据会更麻烦。
Pinia 就是为了保存组件之间的共享数据,如果组件之间有要共享的数据,可以把数据保存到 Pinia 中,Pinia 就是提供一个全局的共享数据存储区域,相当于一个数据仓库,各个组件都可以从中读取和修改数据。
在 Vue2 中我们使用 Vuex 做状态管理,在 Vue3 中使用 Pinia。
14.1 安装Pinia
bash
# npm方式安装
npm install pinia
# yarn方式安装
yarn add pinia
14.2挂载数据存储对象
在项目的 main.ts
中引入 pinia
并挂载到Vue实例上。
bash
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
// 1.引入pinia
import { createPinia } from 'pinia'
const app = createApp(App)
// 2.创建pinia
const pinia = createPinia()
// 3. 安装pinia
app.use(pinia)
// 安装路由
app.use(router)
app.mount('#app')
举例
data:image/s3,"s3://crabby-images/cfc56/cfc56cc18c912366f9d9527704d806ed717ddc96" alt=""
data:image/s3,"s3://crabby-images/1b176/1b17607a3fdc2b9878feb9bfcbce2755893e337e" alt=""
14.3 使用示例
data:image/s3,"s3://crabby-images/2f035/2f03519950843c97336930a2bc1ec7baa9186a9d" alt=""
可看官方文档
14.4 getters
data:image/s3,"s3://crabby-images/eda35/eda356a23cec6d602a5ed175b6cf3e5370c00612" alt=""
14.5 action
data:image/s3,"s3://crabby-images/c73c6/c73c6daaab5ae8ec080ad840a47f4758017304a5" alt=""
14.6 storeToRefs
就是pinia数据使用时直接进行解构赋值,那么会丢失响应性,就需要用到storeToRefs来辅助解构,保持数据的响应性。方法则不需要。
data:image/s3,"s3://crabby-images/d587e/d587e281bff2461734e119a542f74aaa49d475d8" alt=""
15 src目录
data:image/s3,"s3://crabby-images/410d1/410d14311d3add704d594430c285f7fb09d304a9" alt=""
16 别名路径联想设置
data:image/s3,"s3://crabby-images/47493/4749343e4bab1961b9d167dae08d4a9e197d348a" alt=""
17 elementPlus
官网如下:快速开始 | Element Plus (element-plus.org)
安装
bash
# 选择一个你喜欢的包管理器
# NPM
npm install element-plus --save
# Yarn
yarn add element-plus
# pnpm
pnpm install element-plus
安装插件
bash
npm install -D unplugin-vue-components unplugin-auto-import
添加配置:
bash
// vite.config.ts
import { defineConfig } from 'vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
export default defineConfig({
// ...
plugins: [
// ...
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver()],
}),
],
})
17.1 自定义主题
data:image/s3,"s3://crabby-images/52b9f/52b9fd3921fb05299b974e9a1aa900bf7adeb9ba" alt=""
安装
基于vite的项目默认不支持css预处理器,需要开发者单独安装
bash
npm i sass -D
准备定制化的样式文件
bash
/* 只需要重写你需要的即可 */
@forward 'element-plus/theme-chalk/src/common/var.scss' with (
$colors: (
'primary': (
// 主色
'base': #27ba9b,
),
'success': (
// 成功色
'base': #1dc779,
),
'warning': (
// 警告色
'base': #ffb302,
),
'danger': (
// 危险色
'base': #e26237,
),
'error': (
// 错误色
'base': #cf4444,
),
)
)
data:image/s3,"s3://crabby-images/d9a4d/d9a4da7513ddadf4b89a9ea1483a59e625ba6ee0" alt=""
自动导入配置
这里自动导入需要深入到elementPlus的组件中,按照官方的配置文档来
自动导入定制化样式文件进行样式覆盖
按需定制主题配置 (需要安装 unplugin-element-plus)
bash
import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
// 导入对应包
export default defineConfig({
plugins: [
vue(),
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver({importStyle: 'sass'})],
}),
],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url))
}
},
css: {
preprocessorOptions: {
scss: {
// 自动导入定制化样式文件进行样式覆盖
additionalData: `
@use "@/styles/element/index.scss" as *;
`,
}
}
}
})
data:image/s3,"s3://crabby-images/5ae73/5ae73541f2362a68283866ba8e879bd2a1e72280" alt=""
18 axios基础封装
data:image/s3,"s3://crabby-images/f7de4/f7de42783e1a39b1bf7a55282f39db83ba573d7f" alt=""
bash
import axios from 'axios'
// 创建一个新的axios实例
const request = axios.create({
baseURL: 'http://smart-shop.itheima.net/index.php?s=/api',
timeout: 5000
})
// 添加请求拦截器
request.interceptors.request.use(function (config) {
// 在发送请求之前做些什么,
return config
}, function (error) {
// 对请求错误做些什么
return Promise.reject(error)
})
// 添加响应拦截器
request.interceptors.response.use(
function (response) {
// 对响应数据做点什么
const res = response.data
if (res.status !== 200) {
return Promise.reject(res.message)
}
return res
}, function (error) {
// 对响应错误做点什么
return Promise.reject(error)
})
export default request
19 router配置
bash
import { createRouter, createWebHistory } from 'vue-router'
import Login from '@/views/login/index.vue'
import Home from '@/views/layout/index.vue'
const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL),
routes: [{
path: '/',
component: Home,
},
{
path: '/login',
component: Login
},
]
})
export default router
配置路由出口
data:image/s3,"s3://crabby-images/af428/af428a3af9fe0f00d60db4cc28411623f66ee573" alt=""