vue3全局引入elementPlus icon并添加title属性

首先我们要安装icon的依赖

# NPM
$ npm install @element-plus/icons
# Yarn
$ yarn add @element-plus/icons
# pnpm
$ pnpm install @element-plus/icons

然后再main.js或者main.ts中引入

import { createApp,h,renderSlot } from 'vue'
import * as ElIcons from "@element-plus/icons"

const app = createApp(App);
for(const name in ElIcons){
	const icon = ElIcons[name].render()
	ElIcons[name].render = ({$slots,$attrs}) => {
		return h(
			icon,
			[
				icon.children,
				renderSlot($slots,'title'),
				h('title', $attrs.title)
			]
		)
	}
	app.component('elIcon' + name, ElIcons[name]);  // 这样注册的话用法和文档的有点不一样
	// app.component(name, ElIcons[name]);  // 这样注册的话用法就和文档一样了
}

然后就可以直接使用了

// xxx.vue
   <el-icon-delete size="small" class="iconRedBtn" title="删除">   </el-icon-delete>


版权声明:本文为w807139809原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。