利用 pnpm 创建 vue3 项目
data:image/s3,"s3://crabby-images/65222/6522221f8219a28351289ff77fe2e85b067c7c6e" alt=""
data:image/s3,"s3://crabby-images/23ef4/23ef4dd6a3df05341f00f9d19f482fb922f96ffd" alt=""
pnpm 包管理器 - 创建项目
data:image/s3,"s3://crabby-images/e68c1/e68c1b6d299197983549a2e4cb13a0f1dafa4062" alt=""
data:image/s3,"s3://crabby-images/6900d/6900d7bb77a1370f16106e283dc3e0b7b50f769c" alt=""
data:image/s3,"s3://crabby-images/045b7/045b78614628a6a1d38bc943788248ada2bceb17" alt=""
Eslint 配置代码风格(Eslint用于规范纠错,prettier用于美观)
data:image/s3,"s3://crabby-images/6aa93/6aa9313ce41cfb8a77202414c676346df8989fc0" alt=""
在 设置 中配置保存时自动修复
data:image/s3,"s3://crabby-images/1c13a/1c13ab3db3478ee41109154db1dcec4304cc94b2" alt=""
data:image/s3,"s3://crabby-images/ae803/ae803301da7fc4e8c8c9cefceec4e106b33d4880" alt=""
data:image/s3,"s3://crabby-images/52d31/52d31bd8ab3e92c8e536b4a4d15861fb20e084f5" alt=""
提交前做代码检查
husky是一个 git hooks工具(git的钩子工具,可以在特定实际执行特定的命令)
data:image/s3,"s3://crabby-images/dd11a/dd11a3c65056d391fc4e5bddd1f770d79be47680" alt=""
打开 bash终端
data:image/s3,"s3://crabby-images/c32d6/c32d6f17da81eee37d2ac39b154e5ffc79baeb07" alt=""
当前项目没有使用 git进行管理,用 git init 进行初始化
然后进行 husky 工具配置,将会在当前目录中新建 一个 .husky 文件夹,其中一个叫 pre-commit,这就是真正在代码提交之前要做的事情。
提交代码之前,可以让其执行 package.json中配置的全局命令 lint ,该命令基于 eslint 校验 vue文件,js文件等一系列文件,
data:image/s3,"s3://crabby-images/cf17b/cf17bdb0ec22e1c98810e95ea9b2810abdff4b6f" alt=""
data:image/s3,"s3://crabby-images/b38c1/b38c11cf6f6194222afa07f58716a277778bba62" alt=""
手动调用校验
data:image/s3,"s3://crabby-images/58de9/58de938ac0694446e237ec102bb2e86ea0608799" alt=""
因为 eslint 是全面检查。耗时,所以解决办法 : 暂存区 eslint 校验
data:image/s3,"s3://crabby-images/d6cff/d6cffad9fe42fed521628a6e9b643734f6930558" alt=""
安装 lint-staged 包
data:image/s3,"s3://crabby-images/14189/14189c27f14d9f50e515d38fe6ada0e7b2a20964" alt=""
package.json中配置 lint-staged命令,如果要执行该命令,还要配置 scripts,也就是lint-staged,一旦触发该命令,就去执行 lint-staged
data:image/s3,"s3://crabby-images/ea22e/ea22e08243579fd765ac866b0a830681f695faea" alt=""
将内容存放到暂存区并提交
data:image/s3,"s3://crabby-images/783bc/783bc7ed88b2b0c9c24f458909eb9c249b5da964" alt=""
如果代码中有错不能提交,可以先在eslint.cjs中设置关闭,不用管报错先提交
data:image/s3,"s3://crabby-images/68784/68784601daebd23600236d5c28ea920113c6f64c" alt=""
目录调整
data:image/s3,"s3://crabby-images/20275/20275192ee8a27cfdc43ae7bee69d4c52558f3e7" alt=""
将assets,components,stores,views文件夹里的文件删除掉
新增 api 请求文件夹,utils工具文件夹
拷贝全局样式,安装预处理器,进行支持
data:image/s3,"s3://crabby-images/82623/82623f221023facc1958338d9620f214d3fe5817" alt=""
将图片素材拷贝到 assets 中
data:image/s3,"s3://crabby-images/f788e/f788eacd62655a1aec920736f8ec565ed8d78359" alt=""
data:image/s3,"s3://crabby-images/17110/1711001c01dc6ccff27b17309e3898bd2ea13754" alt=""
data:image/s3,"s3://crabby-images/414e0/414e0dcdd71e657585c3abc9080cf4738d94c0f3" alt=""
在main.js中导入验证是否生效,但是该scss文件在当前项目不支持,,还要安装预处理器
data:image/s3,"s3://crabby-images/bf10a/bf10af4c34c40d8bd5a0404239a6fd98bc77b756" alt=""
安装 sass预处理器,然后再 pnpm dev 启动
data:image/s3,"s3://crabby-images/41ab7/41ab7720a1906e9c9a82c9d3480aa2588a995ed8" alt=""
vue-router4路由代码解析:
- 与 vue2 不同:vue2直接导出 VueRouter ,但是vue3是按需导入 createRouter 创建路由(创建实例的方法)
- history有两种模式 createWebHistory 和 createWebHashHistory ,参数是基础路径base,在 vite.config.js中配置
- (在vue3中创建实例用 createApp,创建 路由用 createRouter)
- 如果要在 Vue3 compositionAPI中获取路由对象,要通过路由中导入 useRoute获取路由参数,useRouter获取路由对象
data:image/s3,"s3://crabby-images/913e1/913e173f8b0e2f80221c207a113694b0c1af75f0" alt=""
data:image/s3,"s3://crabby-images/06e0c/06e0c5f5a63cb5fc4cc06e30854919ef0a4e2b12" alt=""
data:image/s3,"s3://crabby-images/3bec2/3bec2c745713a8659a0fe5f8928baf9a0ea2af7d" alt=""
按需引入 Element Plus组件库(因为是 pc 端,所以该组件更合适)
先安装 element-plus
因为按需导入需要两个插件,所以安装两个插件
配置 vite.config.js
data:image/s3,"s3://crabby-images/7afd4/7afd4c275ca7799af9f907f4f63c6a85834302f7" alt=""
data:image/s3,"s3://crabby-images/c52d7/c52d707123a0df7138a61b45a7d371dbf635f100" alt=""
data:image/s3,"s3://crabby-images/cc79d/cc79d8c90e80421e383a6d71922b6be6b03887e9" alt=""
data:image/s3,"s3://crabby-images/e3a3c/e3a3c7f3e50bd062a3e2ac74b675ef783cd466c2" alt=""
配置完成再启动。
可以在项目任意位置使用组件
data:image/s3,"s3://crabby-images/6a2ab/6a2ab71a5edf9a3422703e114016a852c71da258" alt=""
data:image/s3,"s3://crabby-images/b3995/b39958e4d08e324df4f3d07392eef966a33159b7" alt=""
element-plus组件中还能直接使用其他组件而不用引入
pinia多组件共享数据的需求,通过pinia构建仓库和持久化
data:image/s3,"s3://crabby-images/057c4/057c41b8bbe0e7501ca3b853a29944d0c49eaff3" alt=""
在 main.js中引入 createPinia函数,createPinia()会创建一个pinia实例,然后添加到 vue应用中
data:image/s3,"s3://crabby-images/55123/55123894d48110e708f22da12275e835f2cc3ef0" alt=""
在 store文件夹中新建 user.js 模块:defineStore新建 仓库,setToken存储内容,removeToken移除内容,token中显示内容
data:image/s3,"s3://crabby-images/00099/00099c74f845ca1e5139bad73e514228002d446b" alt=""
在组件上使用
data:image/s3,"s3://crabby-images/04659/04659d844ce98afa2b12d96327986b0ff6c1f77b" alt=""
持久化处理
data:image/s3,"s3://crabby-images/80d20/80d20476e5ba45ad1835c41370c4555edd27769e" alt=""
首先安装插件
data:image/s3,"s3://crabby-images/39d1a/39d1a860da429c51e07ad16f3698e33267c561fd" alt=""
将插件应用到 pinia实例中,然后 pinia 实例应用到 vue中
data:image/s3,"s3://crabby-images/f5111/f511169bf1c26cacd8e5af15e5cfae5aed03a749" alt=""
如果希望 某个仓库进行持久化,那么就为其添加第三个参数 persist
data:image/s3,"s3://crabby-images/8dc4f/8dc4f92bcd2a55747b876ee5cb4534584242e0ec" alt=""
关于状态管理 pinia :
- import {createPinia} from 'pinia' 从 pinia库中导入 createPinia 方法(在 main.js中)
- app.use(createPinia()) 在 vue应用中注册 Pinia 实例 。
app.use()
:这是 Vue 3 中的全局插件注册方法。(在 main.js中)- (承上启下)在使用 pinia 时,必须先将pinia实例注册到 vue 应用中,然后才能在仓库 (store)文件中创建和使用 pinia 的 store
- import {defineStore} from 'pinia' 从 pinia库中导入 defineStore函数(在store文件夹下的user.js模块)
- export const useUserStore = defineStore() ,export 是将 useUserStore这个store进行导出,使它能够被外部使用。return 是将 store 中的具体数据和方法(token,setToken,removeToken)暴露出去,让外部能操作这些数据。
- (defineStore中有三个参数,第一个是该仓库唯一标识,第二个是个匿名函数(箭头函数),第三个是进行持久化的参数)
- 要想刷新已有的数据不变,即进行持久化处理,需要安装插件pinia-plugin-persistedstate(git 终端), 在main.js中将其导出,然后应用到 pinia 实例中,而pinia实例用应用到 vue中。然后是 user.js仓库要进行持久化处理,所以为其添加参数 persist:true
Pinia仓库统一管理(两个优化):
- pinia独立维护;原来的 pinia 是堆砌在 main.js中的
- 仓库统一导出;原来的 导出要找到对应的 pinia中的 store,路径很可能找错
pinia独立维护,需要将main.js中与 pinia相关的进行提取到 store文件夹下的 index.js文件中
选中剪切 main.js中与 pinia 有关的代码 ,放入到 stores的index.js中,然后将 pinia 实例导入到 main.js中
data:image/s3,"s3://crabby-images/774a5/774a5cc9337c15d8dcaf156140ba626a077b8a92" alt=""
data:image/s3,"s3://crabby-images/61bd3/61bd36edc1bf5b7fe056b00b2a5f53499b24a546" alt=""
data:image/s3,"s3://crabby-images/9f9ce/9f9ce09b7ab1908155fbcd3fdcaec53861036486" alt=""
仓库统一导出:
stores文件夹下已经有了个 user.js仓库(模块),将来需要处理增加更多的模块处理更多业务,那么会需要一个文件夹modules在stores文件夹下接纳其他仓库文件。在 app.vue中要使用 各个模块下面的数据方法,必须要在app.vue中进行导入,然后获取该各个对象,再然后渲染。
而统一导出就在于 在 app.vue中进行导出各个模块时,必须要写一长串的路径,例如导出user模块,导出路径是 import {useUserStore} from '@/stores/modules/user',每要使用任何一个模块,就必须要导入这么一长串,所以解决办法是将所有模块在 stores文件夹下的 index.js文件中进行导入然后再进行导出,也就是将index.js作为核心出口,那么在app.vue中进行导入的话就直接从 stores文件夹下的 index.js中进行导出了。
data:image/s3,"s3://crabby-images/c47aa/c47aa54531ecc872316cf376df4633cac444806a" alt=""
data:image/s3,"s3://crabby-images/d20b7/d20b77ec91874cddc22568e8a1986635f55d77f7" alt=""