vue3使用vite搭建的项目需要安装的插件/配置方式
作者:sqwu
1.创建项目
项目名称是myProject
vue create myProject
2.vetur报错调整
由于vue3引入组件后不用在components中声明,vetur插件会报错
解决办法:vscode设置 -》 搜索vetur -》 找到下面这个选项,把他关掉。然后重新打开文件,发现没有报错了
3.vite2使用eslint校验
推荐使用这一篇的eslint配置方案👉【vite】vite项目从0开始配置eslint
不使用上一篇的话,就按下面的步骤来~
1.安装eslint
执行命令npx eslint --init
,按照以下选项配置依赖,会顺带下载四个依赖
2.下面开始适配vue3
打开.eslinttrc.js
1.删除extends中的"plugin:vue/essential"
2.删除plugins中的"vue"
3.在extneds中添加'plugin:vue/vue3-recommended'
4.安装pnpm i -D prettier eslint-config-prettier
和pnpm i eslint-plugin-prettier
5.在extends里面加一句:'plugin:prettier/recommended'
4.使用vue-router
1.安装
npm install vue-router@4
2.在src下创建目录router/index.ts
注意引入方式import * as VueRouter from 'vue-router'
。。
直接import VueRouter from 'vue-router'
会报错
Uncaught SyntaxError: The requested module ‘/node_modules/.vite/deps/vue-router.js?v=8dd0ce81’ does not provide an export named ‘default’import * as VueRouter from ‘vue-router’
import * as VueRouter from 'vue-router' const routes = [ { path: '/about', name: 'about', component: () => import('../views/About/index.vue') } ] // 创建路由实例 const router = VueRouter.createRouter({ history: VueRouter.createWebHashHistory(), // hash模式 routes }) export default router
3.在main.ts中应用router
import { createApp } from 'vue' import App from './App.vue' import router from './router' const app = createApp(App) // 使用路由 app.use(router) app.mount('#app')
5.使用vuex
1.安装
npm install vuex@next --save
2.在src下创建目录
store ├── index.js # 我们组装模块并导出 store 的地方 ├── actions.js # 根级别的 action ├── mutations.js # 根级别的 mutation └── modules ├── cart.js # 购物车模块 └── products.js # 产品模块
6.使用vant4
1.安装
npm i vant
2.安装插件实现按需引入组件的样式
// 1.安装插件依赖 npm i vite-plugin-style-import@1.4.1 -D // 2.在vite.config.ts使用插件 import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue' import styleImport, { VantResolve } from 'vite-plugin-style-import' // https://vitejs.dev/config/ export default defineConfig({ plugins: [ vue(), styleImport({ resolves: [VantResolve()] }) ] }) // 3.在页面中使用组件 <template> <van-button>登录</van-button> </template> <script lang="ts" setup> import { Button as VanButton } from 'vant' </script>
7.使用less
1.安装
npm install less less-loader -d
8.移动端将px转为rem
1.安装插件
// 是postcss的插件,用于将像素单元生成rem单位。 npm install postcss-pxtorem -D // 配置可伸缩布局方案,主要是将1rem设为viewWidth/10 npm install amfe-flexible -S
2.在main.ts中
import 'amfe-flexible'
3.在根目录下创建postcss.config.js
// eslint-disable-next-line no-undef module.exports = { plugins: { autoprefixer: { overrideBrowserslist: [ 'Android 4.1', 'iOS 7.1', 'Chrome > 31', 'ff > 31', 'ie >= 8', 'last 10 versions' ], grid: true }, // 把px单位换算成rem单位 'postcss-pxtorem': { rootValue: 75, // 换算的基数(设计图750的根字体为75) propList: ['*'], // *代表将项目中的全部进行转换,单个转换如width、height等 unitPrecision: 5 } }
9.使用axios
1.安装
npm install axios -S npm install qs -S
2.在utils目录下创建http.js,根据项目要求配置请求/响应拦截器
import Axios, { AxiosRequestConfig } from 'axios' import { Toast } from 'vant' // 设置请求头 Axios.defaults.headers.post['Content-Type'] = 'application/json' // 设置超时 Axios.defaults.timeout = 6 * 1000 export default function $http({ url, method, params }: AxiosRequestConfig) { return new Promise((resolve, reject) => { const _axiosConfig = { url, method, params } Axios(_axiosConfig) .then(res => { resolve(res) }) .catch(err => { reject(err) }) }) }
3.在src目录下创建api目录,用来放接口请求
// api/common.ts import $http from '../utils/http' const url = 'https://dev.ylzpay.com/api/follow-up/app/api' export function getDictInfo(params: unknown) { return $http({ url, params }) } // api/index.ts export * from './common'
10.配置请求代理
// 在vite.config.ts server: { port: 8077, open: true, // 自动打开 base: './', proxy: { '/app/api': { target: 'https://dev.ylzpay.com/api/follow-up/app/api', changeOrigin: true, // 打开代理 rewrite: path => path.replace('/app/api', '') } } }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。