Vite + Vue3 项目
pnpm create vite
在要创建项目的文件夹中打开终端,创建项目架子,选择Vue框架
选择JavaScript语法
安装项目依赖
cd .\Vue3-big-event-admin\
pnpm install
运行项目
pnpm dev
vue-router
安装vue-router
pnpm add vue-router
ESLint(非必须)
安装 ESLint 的开发依赖
pnpm i eslint -D
初始化并生成 ESLint 配置文件
npx eslint --init
element-plus
官方文档: https://element-plus.org/zh-CN/
-
安装
pnpm add element-plus
自动按需:
-
安装插件
pnpm add -D unplugin-vue-components unplugin-auto-import
-
然后把下列代码插入到你的 vite.config.js的配置文件中
... import AutoImport from 'unplugin-auto-import/vite' import Components from 'unplugin-vue-components/vite' import { ElementPlusResolver } from 'unplugin-vue-components/resolvers' // https://vitejs.dev/config/ export default defineConfig({ plugins: [ ... AutoImport({ resolvers: [ElementPlusResolver()] }), Components({ resolvers: [ElementPlusResolver()] }) ] })
element-plus 图标库
-
安装 element-plus 图标库
pnpm i @element-plus/icons-vue
Pinia
构建用户仓库 和 持久化
官方文档:Pinia Plugin Persistedstate
安装pinia
pnpm add pinia
-
安装插件 pinia-plugin-persistedstate
pnpm add pinia-plugin-persistedstate -D
-
使用 main.js
import persist from 'pinia-plugin-persistedstate' ... app.use(createPinia().use(persist))
-
配置 stores/user.js
import { defineStore } from 'pinia' import { ref } from 'vue' // 用户模块 export const useUserStore = defineStore( 'big-user', () => { const token = ref('') // 定义 token const setToken = (t) => (token.value = t) // 设置 token return { token, setToken } }, { persist: true // 持久化 } )
axios
们会使用 axios 来请求后端接口, 一般都会对 axios 进行一些配置 (比如: 配置基础地址等)
一般项目开发中, 都会对 axios 进行基本的二次封装, 单独封装到一个模块中, 便于使用
-
安装 axios
pnpm add axios
-
新建
utils/request.js
封装 axios 模块利用 axios.create 创建一个自定义的 axios 来使用
import axios from 'axios' const baseURL = 'http://big-event-vue-api-t.itheima.net' const instance = axios.create({ // TODO 1. 基础地址,超时时间 }) instance.interceptors.request.use( (config) => { // TODO 2. 携带token return config }, (err) => Promise.reject(err) ) instance.interceptors.response.use( (res) => { // TODO 3. 处理业务失败 // TODO 4. 摘取核心响应数据 return res }, (err) => { // TODO 5. 处理401错误 return Promise.reject(err) } ) export default instance
完成 axios 基本配置
import axios from 'axios' import { useUserStore } from '@/stores' import { ElMessage } from 'element-plus' import router from '@/router' const baseURL = 'http://big-event-vue-api-t.itheima.net' const instance = axios.create({ // TODO 1. 基础地址,超时时间 baseURL, timeout: 10000 }) // 请求拦截器 instance.interceptors.request.use( (config) => { // TODO 2. 携带token const useStore = useUserStore() if (useStore.token) { config.headers.Authorization = useStore.token } return config }, (err) => Promise.reject(err) ) // 响应拦截器 instance.interceptors.response.use( (res) => { // TODO 4. 摘取核心响应数据 if (res.data.code === 0) { return res } // TODO 3. 处理业务失败 // 处理业务失败, 给错误提示,抛出错误 ElMessage.error(res.data.message || '服务异常') return Promise.reject(res.data) }, (err) => { // TODO 5. 处理401错误 // 错误的特殊情况 => 401 权限不足 或 token 过期 => 拦截到登录 if (err.response?.status === 401) { router.push('/login') } // 错误的默认情况 => 只要给提示 ElMessage.error(err.response.data.message || '服务异常') return Promise.reject(err) } ) export default instance export { baseURL }