index.vue 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <template>
  2. <div class="svg-demo-container">
  3. <el-card shadow="hover" header="svgIcon:演示(支持本地svg)">
  4. <SvgIcon name="iconfont icon-shuju1" color="red" :size="30" />
  5. <SvgIcon name="ele-Trophy" color="var(--el-color-primary)" :size="30" />
  6. <SvgIcon name="fa fa-flag-checkered" color="#09f" :size="30" />
  7. <SvgIcon :name="logoMini" color="#09f" :size="30" />
  8. </el-card>
  9. <el-card shadow="hover" header="svgIcon:参数" class="mt15">
  10. <el-table :data="tableData" style="width: 100%">
  11. <el-table-column prop="a1" label="参数"> </el-table-column>
  12. <el-table-column prop="a2" label="说明"> </el-table-column>
  13. <el-table-column prop="a3" label="类型"> </el-table-column>
  14. <el-table-column prop="a4" label="可选值"> </el-table-column>
  15. <el-table-column prop="a5" label="默认值"> </el-table-column>
  16. </el-table>
  17. </el-card>
  18. </div>
  19. </template>
  20. <script lang="ts">
  21. import { toRefs, reactive, defineComponent } from 'vue';
  22. import logoMini from '/@/assets/logo-mini.svg';
  23. export default defineComponent({
  24. name: 'makeSvgDemo',
  25. setup() {
  26. const state = reactive({
  27. tableData: [
  28. {
  29. a1: 'name',
  30. a2: 'svg 图标组件名字 / svg 路径 url',
  31. a3: 'string',
  32. a4: '',
  33. a5: '',
  34. },
  35. {
  36. a1: 'size',
  37. a2: 'svg 大小',
  38. a3: 'number',
  39. a4: '',
  40. a5: 14,
  41. },
  42. {
  43. a1: 'color',
  44. a2: 'svg 颜色',
  45. a3: 'string',
  46. a4: '',
  47. a5: '',
  48. },
  49. ],
  50. });
  51. return {
  52. logoMini,
  53. ...toRefs(state),
  54. };
  55. },
  56. });
  57. </script>