先说原理就是将
svg 文件以vue 组件文件的方式使用
需求:我想要在 Element Plus 得评分组件中使用自定义得图标。
先看下
<template> <el-rate v-model="value" :icons="icons" :void-icon="ChatRound" :colors="['#409eff', '#67c23a', '#FF9900']" /> </template> <script lang="ts" setup> import { ref } from 'vue' import { ChatDotRound, ChatLineRound, ChatRound } from '@element-plus/icons-vue' const value = ref() const icons = [ChatRound, ChatLineRound, ChatDotRound] // same as { 2: ChatRound, 4: { value: ChatLineRound, excluded: true }, 5: ChatDotRound } </script>
这里从
两种方法
这里最简单的方法就是第一种
1. 创建 .vue 文件将 svg 代码粘贴进去
创建一个 RateAct.vue 文件, 将 svg 文件的代码复制进去。记得查看是否
<script setup lang="ts"> </script> <template> //<?xml version="1.0" encoding="UTF-8"?> <svg width="14px" height="14px" viewBox="0 0 14 14" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <title>关闭_close-one (2)@2x</title> <g id="数据中心" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" stroke-linejoin="round"> <g id="0数据中心_布局+列表" transform="translate(-375.000000, -85.000000)" stroke="#196FFF"> <g id="快速页签" transform="translate(180.000000, 64.000000)"> <g id="编组-2备份" transform="translate(120.000000, 12.000000)"> <g id="关闭_close-one-(2)" transform="translate(76.000000, 10.000000)"> <path id="路径" d="M6,12 C9.31371,12 12,9.31371 12,6 C12,2.68629 9.31371,0 6,0 C2.68629,0 0,2.68629 0,6 C0,9.31371 2.68629,12 6,12 Z" /> <line id="路径" x1="7.69701" y1="4.30296" x2="4.3029" y2="7.69707" stroke-linecap="round" /> <line id="路径" x1="4.30299" y1="4.30296" x2="7.6971" y2="7.69707" stroke-linecap="round" /> </g> </g> </g> </g> </g> </svg> </template> <style lang="scss"></style>
2. 使用 vite-plugin-svg-icons vite插件
这里默认你会使用
<script setup lang="ts"> </script> <template> <svg-icon icon-class="sl-rate-act" /> </template> <style lang="scss"></style>
最后,按照上面处理好之后。然后按照 Element Plus 的自定义 icon 就可以正常使用
评分组件的文档 。
当然你也可以以一举三, 把这种方式复用在别的组件上,例如:按钮组件的 icon 属性