美文网首页vue
Vue3+TS使用element-plus 动态Icon图标

Vue3+TS使用element-plus 动态Icon图标

作者: 鹏多多 | 来源:发表于2021-11-29 09:31 被阅读0次

1,前言


源于一段话

Element Plus 团队正在将原有组件内的 Font Icon 向 SVG Icon 迁移,请多多留意更新日志, 及时获取到更新信息,Font Icon 将会在第一个正式发布被废弃,请尽快迁移

在此记录一下如何使用element-plus中的icon组件

环境:

  • Vue:3.2.16
  • Element-Plus:1.2.0-beta.3
  • TypeScript:4.4.3
  • Vite:2.6.4

2,使用


文档原话:如果你想像用例一样直接使用,你需要全局注册组件,才能够直接在项目里使用

main.ts中先导入

import * as Icons from '@element-plus/icons'

2.1,方式一


main.ts

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import { store, key } from './store'
import * as Icons from '@element-plus/icons'

const app = createApp(App)
app.use(store, key)
app.use(router)
app.mount('#app')

// 注册全局组件
Object.keys(Icons).forEach(key => {
  app.component(key, Icons[key as keyof typeof Icons])
})

xxx.vue文件中

// html
<template>
   <el-icon :size="20"><alarm-clock /></el-icon>
</template>

或使用动态组件

// html
<template>
  <component class="xxx" :is="iconName"></component>
</template>
// script
export default {
  name: 'Login',
  setup() {
    const iconName = 'Search'
    return {
      iconName
    }
  }
}

2.2,方式二


main.ts

import { createApp, createVNode } from 'vue'
import App from './App.vue'
import router from './router'
import { store, key } from './store'
import * as Icons from '@element-plus/icons'

const app = createApp(App)
app.use(store, key)
app.use(router)
app.mount('#app')

// 创建Icon组件
const Icon = (props: { icon: string }) => {
  const { icon } = props
  return createVNode(Icons[icon as keyof typeof Icons])
}
// 注册Icon组件
app.component('Icon', Icon)

使用动态组件

// html
<template>
  <Icon class="xxx" :icon="iconName"></Icon>
</template>
// script
export default {
  name: 'Login',
  setup() {
    const iconName = 'Search'
    return {
      iconName
    }
  }
}

如果看了觉得有帮助的,我是@鹏多多11997110103,欢迎 点赞 关注 评论;
END

PS:在本页按F12,在console中输入document.querySelectorAll('._2VdqdF')[0].click(),有惊喜哦

往期文章

个人主页

相关文章

  • Vue3+TS使用element-plus 动态Icon图标

    1,前言 源于一段话 Element Plus 团队正在将原有组件内的 Font Icon 向 SVG Icon ...

  • 3D Touch

    icon 图标效果的添加 icon 图标的3D Touch 效果添加可以通过 plist 静态添加与代码动态添加两...

  • 微信小程序(五)基础内容组件

    基础内容组件的使用场景 icon图标组件 (1) icon图标组件: icon组件:是小程序提供的图标组件。借助i...

  • 使用字体图标

    说明:使用字体图标 推荐网站:Icon Font & SVG Icon Sets ❍ IcoMoon https:...

  • Element UI 的图标、按钮、文字链接

    Icon 图标 提供了一套常用的图标集合。使用方法直接通过设置类名为 el-icon-iconName 来使用即可...

  • element-plus,如何动态设置图标?

    element-plus 里面的 icon,以前是字符串形式的,非常容易做成动态的效果,但是新版本改成了组件的形式...

  • 在vue3的渲染函数中使用自定义组件

    起因是这样的:我要在导航菜单中使用element-plus的图标,图标是通过router来配置的: 生成菜单的时候...

  • wx.showToast

    icon的使用 icon主要有三种,success,loading和none 显示成功图标 显示加载图标 不显示图...

  • ionic3 图标的使用

    在项目几乎都会用到了矢量图标icon,我先来说说ionic官网icon图标,官网的图标使用起来很方便,直接用标签引...

  • jQuery Mobile 图标

    添加图标在 或 或 元素中使用 data-icon 属性,添加 data-icon = * 属性 da...

网友评论

    本文标题:Vue3+TS使用element-plus 动态Icon图标

    本文链接:https://www.haomeiwen.com/subject/flikxrtx.html