Vue3中element-plus全局使用Icon图标

Vue项目中使用Element-plus的Icon图标,包括按钮和动态菜单

1、安装图标库

npm install @element-plus/icons

2、注册

main.ts文件中引入并注册

import { createApp } from 'vue'
import App from './App.vue'
import ElementPlus from 'element-plus'
import * as ElIcons from '@element-plus/icons'

const app = createApp(App)
for (const name in ElIcons){
	app.component(name,(ElIcons as any)[name])
}

app.use(ElementPlus).mount('#app')

3、在组件中直接使用

// 结合按钮使用
<el-button type="primary" icon="Edit" >编辑</el-button>
<el-button
  size="mini"
  type="primary"
  class="inline-block"
  icon="More"
  title="详情"
  @click="handleDetail(row.id)"
/>
// 结合el-icon使用
<el-icon>
    <delete />
</el-icon>

4、在el-menu组件中动态使用

如果想在渲染菜单时动态使用icon图标,需要使用动态组件,举个栗子:

// 路由文件
export const routes: Array<RouteRecordRaw> = [
  {
    path: '/',
    component: Layout,
    redirect: 'home',
    children: [
      {
        path: '/home',
        component: () => import('@/views/Home.vue'),
        name: 'Home',
        meta: { title: '首页', icon: 'HomeFilled' },
      },
    ],
  },
]
// 使用el-menu的文件
<template>
  <div>
    <el-scrollbar wrap-class="scrollbar-wrapper">
      <el-menu
        router
        :default-active="activeMenu"
        @open="handleOpen"
        @close="handleClose"
      >
        <template v-for="route in menuList" :key="route.path">
          <el-menu-item v-if="!route.children" :index="route.path">
            <el-icon>
              <component :is="route.meta.icon" />
            </el-icon>
            <!-- <i :class="route.meta.icon" class="iconfont"></i> -->
            <span>{{ route.meta.title }}</span>
          </el-menu-item>
          <el-sub-menu v-else :index="route.path">
            <template #title>
              <el-icon>
                <component :is="route.meta.icon" />
              </el-icon>
              <span>{{ route.meta.title }}</span>
            </template>
            <el-menu-item
              v-for="subRoute in route.children"
              :key="subRoute.path"
              :index="subRoute.path"
            >
            <!-- <el-icon>
              <component :is="subRoute.meta.icon" />
            </el-icon> -->
            <i :class="subRoute.meta.icon" class="iconfont"></i>
              <span>{{ subRoute.meta.title }}</span>
            </el-menu-item>
          </el-sub-menu>
        </template>
      </el-menu>
    </el-scrollbar>
  </div>
</template>

<script lang="ts">
import { defineComponent, computed } from 'vue'
import { useRoute } from 'vue-router'
import { routes } from '@/router/index'

export default defineComponent({
  setup() {
    const route = useRoute()
    const activeMenu = computed(() => {
      const { meta, path } = route
      if (meta.activeMenu) {
        return meta.activeMenu
      }
      return path
    })
    const menuList = computed(
      () => (routes as any).find((item: any) => item.path === '/').children
    )
    return { activeMenu, menuList }
  },
})
</script>

### 解决 Vue3Element Plus 图标不显示的问题 #### 确认安装和配置无误 确保已经正确安装并引入 `Element Plus` 及其图标库。可以通过以下命令来完成安装: ```bash npm install element-plus @element-plus/icons-vue ``` 对于全局引入,可以在项目的入口文件(通常是 `main.js` 或者 `main.ts`)中加入如下代码[^1]: ```javascript import { createApp } from &#39;vue&#39;; import App from &#39;./App.vue&#39;; import ElementPlus from &#39;element-plus&#39;; import * as Icons from &#39;@element-plus/icons-vue&#39;; const app = createApp(App); app.use(ElementPlus); // 注册所有图标组件 Object.keys(Icons).forEach(key => { app.component(key, Icons[key]); }); app.mount(&#39;#app&#39;); ``` 如果采用按需加载的方式,则可以利用工具如 `unplugin-vue-components` 来简化操作,并减少打包体积。先通过 npm 安装必要的依赖项: ```bash npm i -D unplugin-vue-components unplugin-auto-import unplugin-icons vite-plugin-md ``` 接着,在 Vite 配置文件里添加这些插件的支持[^3]: ```javascript import AutoImport from &#39;unplugin-auto-import/vite&#39; import Components from &#39;unplugin-vue-components/vite&#39; export default defineConfig({ plugins: [ AutoImport({ imports: [&#39;vue&#39;, &#39;vue-router&#39;], dts: true, }), Components({ resolvers: [/* 插件解析器 */], }) ] }) ``` #### 排查潜在问题 检查是否存在命名冲突的情况,比如自定义组件名称与内置图标相同可能会导致渲染异常。另外也要确认 HTML 结构是否正确,例如 `<el-icon>` 标签内应该放置具体的图标子标签而不是直接作为文本节点。 最后,查看浏览器开发者工具中的网络请求部分,验证资源是否成功加载以及有无报错信息。如果有跨域或其他类型的错误提示,可能需要调整服务器端设置或修改项目配置以允许相应资源访问。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值