vite.config.ts配置之自動(dòng)導(dǎo)入element-puls方式
根據(jù)Elementplus UI 配置組件及樣式的自動(dòng)導(dǎo)入
自動(dòng)導(dǎo)入推薦
首先你需要安裝unplugin-vue-components 和 unplugin-auto-import這兩款插件
npm install -D unplugin-vue-components unplugin-auto-import
然后把下列代碼插入到你的 Vite 或 Webpack 的配置文件中
Vite
// vite.config.ts
import { defineConfig } from 'vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
export default defineConfig({
// ...
plugins: [
// ...
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver()],
}),
],
})這樣配置太過(guò)簡(jiǎn)單,你會(huì)發(fā)現(xiàn)目錄會(huì)多出兩個(gè)文件,auto-imports.d.ts和components.d.ts。
他們的作用就是不需要開(kāi)發(fā)者手動(dòng)導(dǎo)入,你所使用的組件庫(kù)和依賴(lài)都會(huì)在這里看到。
如下components.d.ts文件。

如果只是以上簡(jiǎn)單的配置auto-imports.d.ts你會(huì)發(fā)現(xiàn)他是一個(gè)空文件,所以還需要你加配置,配置如下:
dts配置生成文件的路徑,默認(rèn)是根路徑。
但是使用默認(rèn)路徑會(huì)存在問(wèn)題,頁(yè)面會(huì)報(bào)依賴(lài)未定義的錯(cuò)誤,放到src下會(huì)解決這一問(wèn)題。
如果不想放在src下,你可以修改tsconfig文件,
如下配置
"include": [
"src/**/*.ts",
"src/**/*.d.ts",
"src/**/*.tsx",
"src/**/*.vue",
"src/style/blackTheme.scss"
]因?yàn)閠s只配置了src下的.d.ts文件,自動(dòng)生成的文件和sec同級(jí)所以報(bào)錯(cuò),將src/**/*.d.ts改為**/*.d.ts即可
imports配置可以自動(dòng)引入的依賴(lài),我配置的是vue,vue-router,axios等,配置完成以后,他會(huì)將你配置的依賴(lài)顯示到auto-imports.d.ts中,
同時(shí)設(shè)置vueTemplate:true,在頁(yè)面使用(ref,reactive)時(shí)不在需要引入。
AutoImport({
resolvers: [ElementPlusResolver()],
dts: "src/auto-imports.d.ts",
include: [
/\.[tj]sx?$/, // .ts, .tsx, .js, .jsx
/\.vue$/,
/\.vue\?vue/, // .vue
/\.md$/, // .md
],
vueTemplate: true,
imports: [
"vue",
"vue-router",
"vue/macros",
// custom
{
"@vueuse/core": [
// named imports
"useMouse", // import { useMouse } from '@vueuse/core',
// alias
["useFetch", "useMyFetch"], // import { useFetch as useMyFetch } from '@vueuse/core',
],
axios: [
// default imports
["default", "axios"], // import { default as axios } from 'axios',
],
},
],
}),
Components({
// allow auto load markdown components under `./src/components/`
extensions: ["vue", "md"],
// allow auto import and register components used in markdown
include: [/\.vue$/, /\.tsx$/, /\.vue\?vue/, /\.md$/],
resolvers: [ElementPlusResolver()],
dts: "src/components.d.ts",
}),如果你想使用$ref也可以配置好,無(wú)需在自己引入了。
$ref定義的變量不需要.value哦
vue({
include: [/\.vue$/, /\.md$/],
// 可以使用$ref
reactivityTransform: true,
}),注意:
自動(dòng)引入會(huì)出現(xiàn)一些樣式的丟失,如:ElMessage、ElNotification等,解決方法如下,在vite.config.ts中進(jìn)行如下配置。
這里會(huì)用到vite-plugin-style-import插件,自己下載即可。
import {
createStyleImportPlugin,
ElementPlusResolve,
} from "vite-plugin-style-import";
// 解決message和notification引入不生效問(wèn)題
createStyleImportPlugin({
resolves: [ElementPlusResolve()],
}),想要?jiǎng)討B(tài)改變?yōu)g覽器中title,可以使用vite-plugin-html,可以進(jìn)行title的動(dòng)態(tài)配置, 然后可以在index.html根目錄下進(jìn)行渲染了
如下:
createHtmlPlugin({
inject: {
data: {
title: "vite+vue3+ts",
description: "系統(tǒng)",
version: "1.0.1",
},
},
}),<title><%-title%></title>
配置全局的css、less、scss,可以如下配置:我在項(xiàng)目main.ts引入了樣式所以這里注釋了
css: {
preprocessorOptions: {
// less: {
// 全局添加less
// additionalData: `@import '@/assets/styles/common/var.less';`,
// javascriptEnabled: true,
// },
},
},然后就是打包時(shí)代碼的一些配置了。
配置去除console.log、debugger以及注釋等。
/** Vite 2.6.x 以上需要配置 minify: "terser", terserOptions 才能生效 */
minify: "terser",
/** 在打包代碼時(shí)移除 console.log、debugger 和 注釋 */
terserOptions: {
//打包后移除console和注釋
compress: {
drop_console: false,
drop_debugger: true,
pure_funcs: ["console.log"],
},
format: {
/** 刪除注釋 */
comments: false,
},
},總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中el-table兩個(gè)表尾合計(jì)行聯(lián)動(dòng)同步滾動(dòng)條實(shí)例代碼
項(xiàng)目開(kāi)發(fā)中遇到一個(gè)比較兩個(gè)form差異的需求,但當(dāng)item過(guò)多就需要滾動(dòng)條,下面這篇文章主要給大家介紹了關(guān)于vue中el-table兩個(gè)表尾合計(jì)行聯(lián)動(dòng)同步滾動(dòng)條的相關(guān)資料,需要的朋友可以參考下2022-05-05
詳解Vue-cli webpack移動(dòng)端自動(dòng)化構(gòu)建rem問(wèn)題
這篇文章主要介紹了詳解Vue-cli webpack移動(dòng)端自動(dòng)化構(gòu)建rem問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
利用Vue實(shí)現(xiàn)一個(gè)markdown編輯器實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于如何利用Vue實(shí)現(xiàn)一個(gè)markdown編輯器的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
ant design vue導(dǎo)航菜單與路由配置操作
這篇文章主要介紹了ant design vue導(dǎo)航菜單與路由配置操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
vue-element換膚所有主題色和基礎(chǔ)色均可實(shí)現(xiàn)自主配置
這篇文章主要介紹了vue-element換膚所有主題色和基礎(chǔ)色均可實(shí)現(xiàn)自主配置,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
使用vue-cli創(chuàng)建項(xiàng)目并webpack打包的操作方法
本文給大家分享使用vue-cli創(chuàng)建項(xiàng)目基于webpack模板打包的配置方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2021-07-07
Vue按時(shí)間段查詢(xún)數(shù)據(jù)組件使用詳解
這篇文章主要為大家詳細(xì)介紹了Vue按時(shí)間段查詢(xún)數(shù)據(jù)組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08

