ElementPlus组件与图标按需自动引入的实现方法
按需自动引入组件
1. 安装ElementPlus和自动导入ElementPlus组件的插件
pnpm install element-plus
pnpm install -D unplugin-vue-components unplugin-auto-import
2. vite.config.ts进行修改
import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue' // ElementPlus自动导入 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(), // 自动导入ElementPlus组件 AutoImport({ resolvers: [ElementPlusResolver()], }), // 自动注册ElementPlus组件 Components({ resolvers: [ElementPlusResolver()], }), ], })
然后就可以进行测试了
<template> <div class="mb-4"> <el-button>Default</el-button> <el-button type="primary">Primary</el-button> <el-button type="success">Success</el-button> <el-button type="info">Info</el-button> <el-button type="warning">Warning</el-button> <el-button type="danger" @click="click">Danger</el-button> </div> </template> <script lang="ts" setup> const click = () => { ElMessage.error('Error Message') } </script>
使用ElementPlus的组件就会自动在根目录下生成下面两个文件
如果想更改这两个文件的位置,可以传入第二个参数,里面指定文件的位置。由于用到了node的东西,所以最好安装下node的ts类型插件,这样编译器不爆红
pnpm i -D @types/node
import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue' // ElementPlus自动导入 import AutoImport from 'unplugin-auto-import/vite' import Components from 'unplugin-vue-components/vite' import { ElementPlusResolver } from 'unplugin-vue-components/resolvers' // 引入node的url模块 import { fileURLToPath } from 'node:url' // https://vitejs.dev/config/ export default defineConfig({ plugins: [ vue(), // 自动导入ElementPlus组件 AutoImport({ resolvers: [ElementPlusResolver()], // 指定ts类型文件位置 dts: fileURLToPath(new URL('./types/auto-imports.d.ts', import.meta.url)), }), // 自动注册ElementPlus组件 Components({ resolvers: [ElementPlusResolver()], // 指定ts类型文件位置 dts: fileURLToPath(new URL('./types/components.d.ts', import.meta.url)), }), ], })
现在文件就生成在了types文件夹内了
按需自动引入图标
1. 首先安装依赖
pnpm install @element-plus/icons-vue
pnpm i -D unplugin-icons unplugin-auto-import
2. vite.config.ts进行修改
import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue' // ElementPlus自动导入 import AutoImport from 'unplugin-auto-import/vite' import Components from 'unplugin-vue-components/vite' import { ElementPlusResolver } from 'unplugin-vue-components/resolvers' // 引入node的url模块 import { fileURLToPath } from 'node:url' // ElementPlus的Icon自动导入 import Icons from 'unplugin-icons/vite' import IconsResolver from 'unplugin-icons/resolver' // https://vitejs.dev/config/ export default defineConfig({ plugins: [ vue(), // 自动导入ElementPlus组件 AutoImport({ resolvers: [ ElementPlusResolver(), // 自动导入图标组件 IconsResolver({ prefix: 'Icon', }), ], // 指定ts类型文件位置 dts: fileURLToPath(new URL('./types/auto-imports.d.ts', import.meta.url)), }), // 自动注册ElementPlus组件 Components({ resolvers: [ ElementPlusResolver(), // 自动注册图标组件 IconsResolver({ enabledCollections: ['ep'], }), ], // 指定ts类型文件位置 dts: fileURLToPath(new URL('./types/components.d.ts', import.meta.url)), }), // 自动安装图标 Icons({ autoInstall: true, }), ], })
然后就可以进行测试了
<template> <div> <el-icon color="pink"> <Edit /> </el-icon> </div> </template>
会发现图标并没有显示出来
其实是换组件名了,可以看下下面的文件,改成对应的组件名就可以显示了
但是有时候,其他组件想用图标,应该怎么写呢?其实正常引入就可以了
<template> <div> <el-icon color="pink"> <IEpEdit /> </el-icon> <el-button type="primary" :icon="Edit" circle /> </div> </template> <script lang="ts" setup> import { Edit } from '@element-plus/icons-vue' </script>
到此这篇关于ElementPlus组件与图标按需自动引入的实现方法的文章就介绍到这了,更多相关ElementPlus按需自动引入内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
element UI 2.15.13与vue2.0表格勾选回显关键demo
这篇文章主要为大家介绍了element UI 2.15.13与vue2.0表格勾选回显关键demo,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11vue+vuecli+webpack中使用mockjs模拟后端数据的示例
本篇文章主要介绍了vue+vuecli+webpack中使用mockjs模拟后端数据的示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。2017-10-10
最新评论