elementplus自动导入配置,vite项目

自动导入组件和图标配置, 这些配置项其实看官网的也是可以的,不过配置图标的时候有个重要的依赖@iconify-json/ep ,官网没提, 也是很容易被忽略的一个依赖,缺了这个依赖,图标的自动导入是没有效果的,

下载依赖
复制代码
  "dependencies": {
    "@element-plus/icons-vue": "^2.3.1", 
    "@iconify-json/ep": "^1.1.15",
    "element-plus": "^2.7.3",
  },
  "devDependencies": {
    "unplugin-auto-import": "^0.17.6",
    "unplugin-icons": "^0.19.0",
    "unplugin-vue-components": "^0.27.0",
  }

配置项

复制代码
import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import path from "path";
import Icons from "unplugin-icons/vite";
import IconsResolver from "unplugin-icons/resolver";
import AutoImport from "unplugin-auto-import/vite";
import Components from "unplugin-vue-components/vite";
import { ElementPlusResolver } from "unplugin-vue-components/resolvers";
// 这个依赖和题目无关
import Inspect from "vite-plugin-inspect";

export default defineConfig({
  plugins: [
    vue(),
    AutoImport({
      imports: ["vue", "vue-router"],
      dts: "src/types/auto-import.d.ts", // 路径下自动生成文件夹存放全局指令
      resolvers: [
        ElementPlusResolver(),
        IconsResolver({
          prefix: "Icon",
        }),
      ],
    }),
    Components({
      dirs: ["src/components"], // 指定需要自动导入的组件所在的目录列表
      dts: "src/types/components.d.ts", // 是否生成类型声明文件 true会生成`.d.ts`的文件,也可以使用字符串地址来指定文件的位置
      resolvers: [
        ElementPlusResolver(),
        IconsResolver({
          enabledCollections: ["ep"],
        }),
      ], // 指定
    }),
    Icons({
      autoInstall: true,
    }),
    //  这个和题目无关
    Inspect(),
  ],
   // 这个和题目无关
  server: {
    host: "0.0.0.0",
  },
 // 这个和题目无关
  resolve: {
    alias: {
      "@": path.resolve(__dirname, "./src"),
      "@back": path.resolve(__dirname, "./src/views/back-stage"),
    },
  },
});
使用
复制代码
// 之前的
//<el-icon><location /></el-icon> 
//<el-icon><DocumentDelete /></el-icon>

//现在的
<el-icon><i-ep-location /></el-icon>
<el-icon><i-ep-DocumentDelete /></el-icon>
// 这样拆开写也是可以的
<el-icon><i-ep-document-delete /></el-icon>
相关推荐
likuolei3 小时前
XSL-FO 软件
java·开发语言·前端·数据库
正一品程序员3 小时前
vue项目引入GoogleMap API进行网格区域圈选
前端·javascript·vue.js
j***89463 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端
star_11123 小时前
Jenkins+nginx部署前端vue项目
前端·vue.js·jenkins
im_AMBER3 小时前
Canvas架构手记 05 鼠标事件监听 | 原生事件封装 | ctx 结构化对象
前端·笔记·学习·架构
JIngJaneIL3 小时前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·农产品电商系统
Tongfront3 小时前
前端通用submit方法
开发语言·前端·javascript·react
c***72743 小时前
SpringBoot + vue 管理系统
vue.js·spring boot·后端
可爱又迷人的反派角色“yang”3 小时前
LVS+Keepalived群集
linux·运维·服务器·前端·nginx·lvs
han_3 小时前
前端高频面试题之CSS篇(二)
前端·css·面试