赞
踩
npm i unplugin-auto-import unplugin-vue-components -D
文档很简单, 还需自行探索, 大佬一贯思想, 他很懒, 不想写文档, 看源码就够了
下面的是 vue vue-router elementui 组件库的自动导入。也有其他的选项可以自行探索。
// https://vitejs.dev/config/ 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(), WindiCSS(), AutoImport({ imports: ['vue', 'vue-router'], }), Components({ resolvers: [ElementPlusResolver({ ssr: false, directives: false })], dirs: ['src/layout/components', 'src/components'], dts: true, }), ] })
npm run dev
, 执行完成之后, 会生成两个文件 auto-imports.d, components.d
在这解释一下,
auto-imports.d
其实本质就是利用全局declare
来将 vue 的 api 声明为全局的变量, 下面是代码
components.d
其实本质就是利用GlobalComponents
, 来将组件注册到全局组件里面, 这样就可以自动推断组件类型了;volar 插件就利用了这个API
, 便于插件推导组件类型的,naive
ui框架 就是使用的这个api,如果感性去可以去代码库看一下 地址
不过编译过程肯定有复杂的处理, 还没仔细研究
"include": [
"src/**/*.ts",
"src/**/*.d.ts",
"src/**/*.tsx",
"src/**/*.vue",
"auto-imports.d.ts",
"components.d.ts"
],
<script setup lang="ts"> onMounted(() => {}) </script> <template> <HelloWorld msg="dsfsfsd" /> </template> <style> #app { font-family: Avenir, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
vue(),
WindiCSS(),
AutoImport({
imports: ['vue']
}),
Components({
resolvers: [ElementPlusResolver()] // 这里就是相关ui库的解析工具, 里面的选项有是否使用自动导入样式 如果需要通过 var 变量改变主题 需要注意一下
})
]
})
关于 element 组件自动导入存在 loading 指令无法正常使用的问题, 需要在 mian.ts 文件里面自行导入
issue
创建文件 element-plus-directive.ts, 这个文件就是导入你需要的指令和样式, 然后注册到全局组件
import { ElLoading, ElMessage, ElMessageBox } from 'element-plus' import 'element-plus/es/components/message/style/css' import 'element-plus/es/components/loading/style/css' import 'element-plus/es/components/message-box/style/css' import type { App } from '@vue/runtime-core' /** * 按需导入 Element Plus 组件 * Vite 插件 https://github.com/antfu/unplugin-vue-components * @param app {App} */ export default function styleImport(app: App<any>) { const components = [ElLoading, ElMessage, ElMessageBox] components.forEach((v) => { app.use(v) }) // 将message组件挂载到 window 对象 self.$message = ElMessage self.$messageBox = ElMessageBox return app }
在 main 中引入
const app = createApp(App)
elemetPlusDirectives(app).mount('#app')
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。