Vue3自動(dòng)引入組件與組件庫的方法實(shí)例
前言
在做vue3項(xiàng)目中時(shí),每次使用都需要先進(jìn)行引入,用ts的還好,會有爆紅提示,如果是使用js開發(fā)的很多時(shí)候都會等到編譯的時(shí)候才發(fā)現(xiàn)哪里哪里又沒有引入,就會很浪費(fèi)時(shí)間,偶然發(fā)現(xiàn)一款好用的組件可以幫助我們很好的解決這種問題。
首先下載
安裝
yarn add unplugin-auto-import -D
引入
在vite.config.ts中
因?yàn)槭遣寮?所以在我們的plugins下 寫入我們導(dǎo)入的名字
imports
在我們的 AutoImport 下第一個(gè)屬性 imports 代表著的就是我們那些文件需要自動(dòng)導(dǎo)入
我們這里就寫了vue vue-router pinia 在項(xiàng)目中使用的時(shí)候就可以不用我們手動(dòng)導(dǎo)入直接使用了
這里注意我們的imports 是一個(gè)數(shù)組
dts
第二個(gè)屬性就是我們的dts
dts為true就代表著會自動(dòng)生成一個(gè)ts文件可以查看導(dǎo)入的信息。
include
這里include是可以匹配對應(yīng)的文件
是一個(gè)數(shù)組里面寫匹配的正則
引入
在引入的時(shí)候需要引入unplugin-auto-import下的vite
import AutoImport from 'unplugin-auto-import/vite'
plugins: [vue(),Vuejsx(),
AutoImport({
include: [
/\.[tj]sx?$/,
/\.vue$/,
/\.vue\?vue/,
],
dts: true,
imports: ['vue', 'vue-router', 'pinia']
})]然后在頁面使用

會發(fā)現(xiàn)爆紅,這里是因?yàn)樵诋?dāng)前頁面沒有引用導(dǎo)致,(這就是這個(gè)組件使用ts的缺陷還沒找到解決辦法)不用管它 直接運(yùn)行項(xiàng)目
運(yùn)行不會有報(bào)錯(cuò)

發(fā)現(xiàn)會在src同級目錄下自動(dòng)生成一個(gè)同級文件 auto-imports.d.ts

打開會發(fā)現(xiàn)里面有我們各種的導(dǎo)入

到這里我們的引入就完成了。
自動(dòng)引入組件庫
安裝
yarn add unplugin-vue-components -D
下載ant-design測試
npm i --save ant-design-vue
在vite.config.ts中引入
import Components from 'unplugin-vue-components/vite'
在引入import { } from 'unplugin-vue-components/resolvers' ctry加鼠標(biāo)進(jìn)入resolvers.d.ts

里面有各大主流組件庫的名字 找到我們需要引入的組件庫 ant -design(需要配置其他的組件庫可找對應(yīng)組件庫名)
找到并引入 AntDesignVueResolver
import { AntDesignVueResolver } from 'unplugin-vue-components/resolvers'
首先也需要在plugins中引入我們定義的名字 Components
Components({})
是一個(gè)對象
dts
第一個(gè)參數(shù)跟上面一樣設(shè)置為true也是會自動(dòng)生成一個(gè)d.ts的文件
dirs
第二個(gè)參數(shù)就是dirs就是配置你的目錄,你可以設(shè)置src,或者src/componets或者你需要配置的地方的組件讓他自動(dòng)導(dǎo)入,其他的組件不管
extensions
擴(kuò)展屬性
['vue', 'jsx', 'tsx', 'ts', 'js'],
resolvers
最后這個(gè)resolvers就是我們的包自動(dòng)導(dǎo)入
將我們上面引入的AntDesignVueResolver導(dǎo)進(jìn)來進(jìn)行配置
resolvers: [
AntDesignVueResolver({
})
]
Components({
dts: true,
dirs: ['src/components'],
extensions: ['vue', 'jsx', 'tsx', 'ts', 'js'],
resolvers: [
AntDesignVueResolver({
})
]
})AntDesignVueResolver
importStyle
就是AntDesignVueResolver第一個(gè)參數(shù) 可以設(shè)置我們的less預(yù)處理器
importLess
需要 設(shè)置為true開啟
這里的操作配置就相當(dāng)于引入的包以less的方式導(dǎo)入,
這里支持less 就需要將less也在項(xiàng)目中配置
CSS配置less
下載less less-loader
yarn add less less-loader -D
在preprocessorOptions中配置less,因?yàn)槭侵饕v自動(dòng)安裝,這里配置就不詳細(xì)講了
css: {
// https://cn.vitejs.dev/config/#css-preprocessoroptions
preprocessorOptions: {
less: {
modifyVars: {
// 此處也可設(shè)置直角、邊框色、字體大小等
'primary-color': '#27ba9b'
},
javascriptEnabled: true,
lessOptions: {
javascriptEnabled: true
},
},
},
},在app.vue中導(dǎo)入一個(gè)button
<script setup lang="ts">
const msg = ref<string>("");
</script>
<template>
<input type="text" v-model="msg" />
{{ msg }}
<a-button type="primary">Primary Button</a-button>
</template>運(yùn)行
自動(dòng)生成components.d.ts文件

里面就是組件幫助我們自動(dòng)創(chuàng)建的,這里創(chuàng)建的子組件也不需要引入即可使用

可以發(fā)現(xiàn)我們的HellowWord沒有引入也可以在頁面中使用,就是因?yàn)樵赾omponents.d.ts中已經(jīng)自動(dòng)導(dǎo)入了。
看到這里有沒有馬上在項(xiàng)目中使用的想法呢?
好啦,到這里我們的Vue3自動(dòng)引入組件,組件庫就完成了。
最后附上完整代碼
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import Vuejsx from '@vitejs/plugin-vue-jsx'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { AntDesignVueResolver } from 'unplugin-vue-components/resolvers'
// https://vitejs.dev/config/
export default defineConfig({
server:{
open:true,
port:8080,
host:'localhost',
headers: {
'Access-Control-Allow-Origin':'*',
},
// 配置代理
},
css: {
// https://cn.vitejs.dev/config/#css-preprocessoroptions
preprocessorOptions: {
less: {
modifyVars: {
// 此處也可設(shè)置直角、邊框色、字體大小等
'primary-color': '#27ba9b'
},
javascriptEnabled: true,
lessOptions: {
javascriptEnabled: true
},
},
},
},
plugins: [vue(),Vuejsx(),
AutoImport({
include: [
/\.[tj]sx?$/,
/\.vue$/,
/\.vue\?vue/,
],
dts: true,
imports: ['vue', 'vue-router', 'pinia']
}),
Components({
dts: true,
dirs: ['src/components'],
extensions: ['vue', 'jsx', 'tsx', 'ts', 'js'],
resolvers: [
AntDesignVueResolver({
importStyle: 'less',
importLess: true
})
]
})]
})
總結(jié)
到此這篇關(guān)于Vue3自動(dòng)引入組件與組件庫的文章就介紹到這了,更多相關(guān)Vue3自動(dòng)引入組件 組件庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mpvue中配置vuex并持久化到本地Storage圖文教程解析
這篇文章主要介紹了mpvue中配置vuex并持久化到本地Storage的教程詳解,# 配置vuex和在vue中相同,只是mpvue有一個(gè)坑,就是不能直接在new Vue的時(shí)候傳入store。本文分步驟給大家介紹的非常詳細(xì),需要的朋友參考下吧2018-03-03
intellij?idea+vue前端調(diào)試配置圖文教程
在Vue項(xiàng)目開發(fā)過程中,當(dāng)遇到應(yīng)用邏輯出現(xiàn)錯(cuò)誤,但又無法準(zhǔn)確定位的時(shí)候,知曉Vue項(xiàng)目調(diào)試技巧至關(guān)重要,debug是必備技能,這篇文章主要給大家介紹了關(guān)于intellij?idea+vue前端調(diào)試配置的相關(guān)資料,需要的朋友可以參考下2024-09-09
詳解如何實(shí)現(xiàn)一個(gè)簡單的 vuex
本篇文章主要介紹了如何實(shí)現(xiàn)一個(gè)簡單的 vuex,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02
Vue實(shí)現(xiàn)圖片預(yù)覽功能的詳細(xì)指南
在現(xiàn)代 web 應(yīng)用程序中,圖片預(yù)覽功能提升了用戶體驗(yàn),使用戶可以在上傳圖片之前查看圖片內(nèi)容,本文將詳細(xì)介紹如何在 Vue.js 應(yīng)用中實(shí)現(xiàn)圖片預(yù)覽功能,包括基本實(shí)現(xiàn)、進(jìn)階功能、與 Element UI 的集成、常見優(yōu)化技巧以及與其他庫的結(jié)合使用,需要的朋友可以參考下2024-09-09
Vue使用watch同時(shí)監(jiān)聽多個(gè)值的實(shí)現(xiàn)方法示例
這篇文章主要為大家介紹了Vue中使用watch同時(shí)監(jiān)聽多個(gè)值的實(shí)現(xiàn)方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
vuejs響應(yīng)用戶事件(如點(diǎn)擊事件)
本篇文章主要介紹了vuejs響應(yīng)用戶事件(如點(diǎn)擊),通過vuejs響應(yīng)用戶事件的技巧,具有一定的參考價(jià)值,有興趣的小伙伴們可以參考一下。2017-03-03

