最近时间总算是闲了下来,准备着手搭建一个基础模板,为后面新项目准备的,搭建过程中遇到不少问题,现在总结下来给大家使用。
项目初始化
本项目已vite开始,所以按照vite官方的命令开始。这里使用的命令行的方式来搭建基础项目:
yarn create vite my-vue-app --template vue
执行完之后的项目结构是这样的:
接下来就开始着手安装东西了(腥风血雨要开始了!)。
安装router和pinia
安装这两个的过程还是比较简单的,基本是可以按照官方文档就可以做完,接下来执行命令:
yarn add vue-router@4
在根目录新建router
文件夹,新建index.ts
文件,代码如下:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router
这时候需要在main.ts
文件中引入
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')
这时候你执行代码的时候,会发现控制台报错,如下:
这是因为vite不能识别@
,这其实跟webpack的配置是一样的,重定向一下就可以了。打开vite.config.ts
加入以下的内容:
import { defineConfig } from 'vite'import path from 'path'import vue from '@vitejs/plugin-vue'// https://vitejs.dev/config/export default defineConfig({ plugins: [vue()],+ resolve: {+ alias: [+ {+ find: '@',+ replacement: path.resolve(__dirname, 'src'),+ },+ ],+ },})
这时候还是不行的,因为是不能识别到path这个东西的,需要安装@types/node
yarn add @types/node -D
同时需要在tsconfig.node.json
中添加compilerOptions.allowSyntheticDefaultImports: true,即如下:
"compilerOptions":{+ allowSyntheticDefaultImports:true}
这时候就可以解决之前的报错了。接下来就是pinia
的安装:
yarn add pinia
pinia可以说是现在vuex的潮流,必须要尝尝鲜,新增store
同时在文件新增index.ts
文件
import { defineStore }from 'pinia'const useStore = defineStore('main',{ state:()=>{ return { counter: 0, name:'RadiomM' } }, actions:{ reset(){ this.$reset() } }})export default useStore
本人粗略的使用了一下里面的语法,非常的好用,这里只展示最简单的示例。在main.ts
里面再引入一下即可。
import { createApp } from 'vue'import router from './router'import { createPinia} from 'pinia'import App from './App.vue'createApp(App).use(createPinia()).use(router).mount('#app')
安装ESlint
安装eslint可以说一个比较麻烦的一件事,我是翻阅了不少文章,参考了别人文章的配置,但是途中还是踩了不少坑,有插件也只知道安装,并不知道为了解决什么问题而安装,所以这次我的展示会比较的长,目的是为了介绍每个插件的用途。开始!运行一下命令:
yarn add vue-router@40
按照下面步骤选择,可以完成基本的eslint配置:
选择ESlint用途
什么模块引入方式 什么框架使用eslint 是否使用typescript 运用环境选择 选择流行规则 选择Airbnb规则 用什么类型文件做载体 是否开始安装 用什么工具安装
完成上面步骤后,可以看到项目里新增一个eslintrc.js
文件,但是这仅仅是刚开始,接下来看各种坑吧。
eslint的vue规则需要切换
如下报错,在app.vue可以看到,这里提示需要一个根元素,实际上vue3已经不需要写一个根元素了。
这时候需要修改.eslintrc.js
文件,如下:
yarn add vue-router@41
这时候,你去看其他文件的时候会有linebreak-style
的错误,这是因为eslint默认是unit
的也就是lr
行尾,现在可以直接在.eslintrc.js
文件中添加新规则:
yarn add vue-router@42
注意,如果加了之后没有效果,需要重启vscode才能有效果,实际上很多新加的东西都需要重启才能有效果。 这时候整个项目就不存在报错,接着进行下一步。
安装prettier
单纯安装eslint只会提示你代码的格式错误,并不会帮你自动修改,这时候就需要这个prettier来实现这个功能。执行下面的命令:
yarn add vue-router@43
这时候需要重新修改.eslintrc.js
文件,如下:
yarn add vue-router@44
这里解释一下这些插件:eslint-plugin-prettier
这个插件主要禁用掉了一些不必要的以及和 Prettier 相冲突的 ESLint 规则。eslint-config-prettier
不符合prettier规则的时候会报一个错误,同时可以用eslint --fix命令修复。 同时需要新增.prettierrc.js
文件,写入下面东西:
yarn add vue-router@45
接着我们可以再package.json
中新增一个命令:
yarn add vue-router@46
然后可以运行一下命令,感受一下双巨头的加持(啥代码的都没有,一点感受都没有):
yarn add vue-router@47
当然这样也只能是在运行命令的时候才能修复,我们想要的是保存代码的时候就可以实现代码自动格式化,这时候需要在vscode
的setttings.json
文件中添加下面内容:
yarn add vue-router@48
同时你的vscode需要安装两个插件,如下:
这时候在你保存的时候,就可以代码格式化了。当然,我们也可以在运行项目的时候就让这些错误格式报错。安装插件
yarn add vue-router@49
然后在vite.config.ts
文件中添加:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router0
现在你可以试着重新启动项目, ESLint 的错误已经能够及时显示到命令行窗口中了。
----------------------------------------补充----------------------------------------- 在你运行yarn add vue-router@47
命令的时候,会出现下面的错误:
这里需要一个个问题慢慢解决,首先是import/extensions
问题,主要是airbnb
规范中的配置是跟我们vue项目不一样的,所以在eslint规则中需要加入下面:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router1
而解决依赖位置报错问题import/no-extraneous-dependencies
,其实他这个报错是错误的,但是同样解决,同样是新增规则:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router2
接下来是比较麻烦的import/no-unresolved
,这个参考的国外友人的配置解决的。 首先需要安装插件:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router3
接下来需要在.eslintrc.js
文件中添加如下(和rules同级):
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router4
关于这个配置其实还有js版本的解决办法,可以参考这个网站 最后展示.eslintrc.js
文件
module.exports = { env: { browser: true, es2021: true, 'vue/setup-compiler-macros': true, }, extends: [ 'plugin:vue/vue3-recommended', 'airbnb-base', 'plugin:prettier/recommended', ], parser: 'vue-eslint-parser', parserOptions: { ecmaVersion: 'latest', parser: '@typescript-eslint/parser', sourceType: 'module', }, plugins: ['vue', '@typescript-eslint'], rules: { 'prettier/prettier': 'error', 'linebreak-style': ['error', 'windows'],+ 'import/extensions': [+ 'error',+ 'ignorePackages',+ {+ js: 'never',+ jsx: 'never',+ ts: 'never',+ tsx: 'never',+ },+ ],+ import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router2 },+ settings: {+ 'import/resolver': {+ typescript: {}, // this loads <rootdir>/tsconfig.json to eslint+ },+ },}
安装stylelint
这个就是样式的格式化插件,不废话直接安装:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router6
同样的需要新建.stylelintrc.js
文件,写入以下内容:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router7
再次同样的,需要在settings.json
文件中添加配置,目标同样是为了保存文件自动格式化。
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router8
这时候可以在package.json
文件添加命令:
import { createRouter,createWebHashHistory, RouteRecordRaw} from 'vue-router'import HelloWorld from '@/components/HelloWorld.vue'const routes: Array<RouteRecordRaw> = [ { path: '/', name: 'HelloWorld', component: HelloWorld }]const router = createRouter({ history: createWebHashHistory(), routes})export default router9
其实跟上面的eslint的命令差不多。当然,同样有运行时报错的插件,如下:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')0
然后在 Vite 配置文件中添加如下的内容:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')1
最后展示文件内容:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')2
同样的,可以在vscode中安装下面的插件。
安装husky
安装这个主要是为了卡点,在提交信息的时候,会校验代码格式,保证线上代码规范统一,执行下面命令:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')3
紧接着初始化huskynpx husky install
,并将husky作为项目启动前脚步,如下:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')4
添加 Husky 钩子,在终端执行如下命令:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')5
注意window系统下双引号内容需要连接符,mac系统则不需要 接着你将会在项目根目录的.husky
目录中看到名为pre-commit
的文件,里面包含了 git commit
前要执行的脚本。现在,当你执行 git commit
的时候,会首先执行 npm run lint
脚本,通过 Lint 检查后才会正式提交代码记录。但是会出现这样一种情况,就是我只修改了一个文件,这个检查还是全量检查,所以这个时候需要另外一个工具了。lint-staged
就是用来解决上述全量扫描问题的,可以实现只对存入暂存区
的文件进行 Lint 检查,大大提高了提交代码的效率。
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')6
然后在 package.json
中添加如下的配置:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')7
接下来我们需要在 Husky 中应用lint-stage
,回到.husky/pre-commit
脚本中,将原来的npm run lint
换成如下脚本:
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')8
这样,我们便实现了提交代码时的增量 Lint 检查
。
安装commitlint
不知道你有没有遇到过,团队合作的时候,你的同事在提交代码的时候,提交信息只有提交
二字!!根本不懂他改了什么功能或者是新增了什么需求,或者是改了什么bug!这时候我们就要规范起提交信息来!
import { createApp } from 'vue'import router from './router'import App from './App.vue'createApp(App).use(router).mount('#app')9
接下来新建.commitlintrc.js
:
import { defineConfig } from 'vite'import path from 'path'import vue from '@vitejs/plugin-vue'// https://vitejs.dev/config/export default defineConfig({ plugins: [vue()],+ resolve: {+ alias: [+ {+ find: '@',+ replacement: path.resolve(__dirname, 'src'),+ },+ ],+ },})0
这个插件提交的规范主要由两部分组成,分别为<type>
和subject
。常用的 type
值包括如下:
feat
: 添加新功能。
fix
: 修复 Bug。
chore
: 一些不影响功能的更改。
docs
: 专指文档的修改。
perf
: 性能方面的优化。
refactor
: 代码重构。
test
: 添加一些测试代码等等。 接下来我们将commitlint
的功能集成到 Husky 的钩子当中,在终端执行如下命令即可:
import { defineConfig } from 'vite'import path from 'path'import vue from '@vitejs/plugin-vue'// https://vitejs.dev/config/export default defineConfig({ plugins: [vue()],+ resolve: {+ alias: [+ {+ find: '@',+ replacement: path.resolve(__dirname, 'src'),+ },+ ],+ },})1
然后就可以完成提交信息的规范了,当提交的信息不符合规范时,会对提交操作的终止,并提示错误,至此我们就完成了这次的从零搭建项目了。
总结
这次的搭建过程中并没有安装css处理插件,但是在vite中安装诸如sass、less
都是比较简单的,就举例子sass
直接运行yarn add sass
即可(本文其实很多插件都是以sass为模板安装的),那么这次的坑就踩到这里了,期待下次的踩坑之旅。 仓库地址
参考:《深入浅出vite》 从 0 开始手把手带你搭建一套规范的 Vue3.x 项目工程环境
原文:https://juejin.cn/post/7101961810751782949