vue3中vite的配置

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue3中vite的配置相关的知识,希望对你有一定的参考价值。

参考技术A 上一节 - 搭建vue3+typescript+vite+yarn项目

在vue2里,我们使用webpack打包工具,一些基本配置我们都是熟悉不能再熟悉,但在vite里,有什么不同呢?

参考链接 - vite 中文文档

vue2里,针对webpack的配置,是基于vue.config.js文件
但在基于vite的vue3里,配置文件是vite.config.js
我构建的是ts版本的vue3项目,那么我的配置文件就是vite.config.ts
而且该文件项目创建的时候已经默认生成了
新创建的项目配置文件,仅仅配置vue的支持,如下:

配置反向代理,利用 server配置项

配置项一目了然,跟vue2的vue.config.js的配置大同小异
这里主要说明下,我proxy里的config

config变量来源于全局变量

这需要在根目录下创建两个命名为:.env.development、.env.production的文件
编写相关的变量:

vue2中使用习惯了开箱即用的路径别名,但在vue3的ts项目里,如果直接使用,是会报错的:

这样配置后,引入组件就能正常被编译了

下一节 - vue3中引入router和vuex

vite+vue3+ts中的vue-router基本配置


其实vue-router配置比较简单了,之前写过一篇非ts的配置:​​vite2 + vue3 中 vue-router4 基本使用(路由基本配置)​​ 大家有兴趣可以看看,加上ts其实就是多了类型的约束,vue-router中已经给我们提供了RouteRecordRaw类型,可能我们需要在路由对象中自定义配置属性的时候就得去扩展一下RouteRecordRaw类型了,下面就介绍下

1. 首先安装 

npm i vue-router@4

2. 配置相关 

 ① 配置别名

vite.config.ts  

vite+vue3+ts中的vue-router基本配置_基本配置

  

代码: 

import  defineConfig  from vite
import vue from @vitejs/plugin-vue
const path = require(path)
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: [
vue(),
AutoImport(
resolvers: [ElementPlusResolver()],
),
Components(
resolvers: [ElementPlusResolver()],
)
],
// 别名
resolve:
alias:
//设置别名
@: path.resolve(__dirname, ./src)


)

注意:如果这时候给你报一个require is not defind,我们可以 npm i @types/node --save-dev装一下,然后在tsconfig.json中配置compilerOptions.types: ["node"],compilerOptions.paths: "@": ["src"], "@/*": ["src/*"]如果没报上面错误就可以忽略

报这个原因就是vite中不能使用require的,在vue-cli3搭建的vue2项目中可以使用是因为webpack帮我们解决了 

② 路由配置 

@/router/index.ts 

import  createRouter, createWebHashHistory, RouteRecordRaw  from vue-router
import viewsRouter from ./views
import pageRouter from ./page

// 对RouteRecordRaw类型进行扩展
export type AddRouteRecordRaw = RouteRecordRaw &
hidden?: boolean


const router = createRouter(
history: createWebHashHistory(),
routes: [...viewsRouter, ...pageRouter] as AddRouteRecordRaw[]
)

export default router

我习惯将咱们的路由中的routes拆分开来,就是登录页、404页面、断网页面、锁屏页面等这类的页面单独放一块儿,放在page下,然后主要的业务页面放在views中 ,然后在这里统一引入一下就可以,可以看下这两个拆分开来的文件:

@/router/page/index.ts 

import  AddRouteRecordRaw  from ../index

export default [

path: /login,
name: login,
hidden: false, // 自定义添加的属性
meta:
title: 登录
,
component: () => import(@/page/login.vue)
,

path: /:pathMatch(.*), // 或者 /:pathMatch(.*)*
name: 404,
hidden: false, // 自定义添加的属性
meta:
title: 404
,
component: () => import(@/page/notfount.vue)

] as AddRouteRecordRaw[]

这里注意404页面,我们在vue2中给path设置*号就会匹配到任何找不到页面,然后我们就会给其跳转到我们自定义的404页面,但是在vue3中移除了*,这里要匹配404页面就得给path设置 "/:pathMatch(.*)",或者 "/:pathMatch(.*)*"才可以

@/router/views/index.ts 

import  AddRouteRecordRaw  from ../index
import Layout from @/views/main.vue

export default [

path: /,
component: Layout,
name: main,
meta:
title: 容器
,
redirect: path: /index ,
children: [

path: index,
name: index,
meta:
title: 主页
,
component: () => import(@/views/pages/index.vue)

]
,

path: /user,
component: Layout,
children: [

path: index,
name: user,
meta:
title: 用户管理
,
component: () => import(@/views/pages/user.vue)

]

] as AddRouteRecordRaw[]

还需要注意的是,vue-router中给我们提供的 RouteRecordRaw  类型中,没有hidden这个属性,我们有时候可能会添加一些自定义属性,做一些想做的事,这时候就得对RouteRecordRaw类型进行扩展,就像上面我会自定义一个 AddRouteRecordRaw 类型对RouteRecordRaw类型进行扩展,及拿过来用的时候就使用 AddRouteRecordRaw 类型就可以了

最后在main.ts中引入并use一下即可 

vite+vue3+ts中的vue-router基本配置_自定义_02

代码: 

import  createApp  from "vue";
import App from "./App.vue";
import store, key from "./store";
import router from ./router
import element-plus/dist/index.css

const app = createApp(App)

app.use(store, key).use(router)

app.mount("#app");

 然后路由使用是一样的,基本上就是通过 useRouter 和 useRoute,来实现页面的跳转和传参,在之前的博客也有写过,在开始已经将链接附上,这里就不再赘述。

以上是关于vue3中vite的配置的主要内容,如果未能解决你的问题,请参考以下文章

vite为vue3配置@路径,vite路径配置

vite为vue3配置@路径,vite路径配置

vite为vue3配置@路径,vite路径配置

vue3+vite+ts 配置别名@报错

vite配置 vue3中怎么使用svg图标

vite配置 vue3中怎么使用svg图标