Icon 图标
我们内置的一组预设图标
import { DuIcon } from 'dangoui'
示例
使用介绍
<template>
<PreviewBlock title="使用 icon 属性">
<DuIcon :icon="iconRefresh" />
<DuIcon :icon="iconRefresh" color="primary" />
<DuIcon :icon="iconRefresh" :size="32" />
</PreviewBlock>
<PreviewBlock title="最简例子">
<DuIcon name="two-column" />
<DuIcon name="label-related" />
</PreviewBlock>
<PreviewBlock title="改变颜色/使用 CSS color 属性">
<div class="text-blue text-sm">
<DuIcon name="refresh" class="mr-4px" />
<span>这是一个图标加文案,都是同一种颜色</span>
</div>
</PreviewBlock>
<PreviewBlock title="改变颜色/直接使用 color 属性">
<DuIcon name="refresh" color="primary" />
<DuIcon name="refresh" color="secondary" />
<DuIcon name="refresh" color="success" />
<DuIcon name="refresh" color="warning" />
<DuIcon name="refresh" color="error" />
<DuIcon name="refresh" color="trade" />
<DuIcon name="wifi" color="#06b6d4" />
</PreviewBlock>
<PreviewBlock title="改变大小">
<DuIcon name="scanning" :size="32" />
<DuIcon name="copylink" :size="32" />
</PreviewBlock>
<PreviewBlock title="使用图片链接">
<DuIcon name="https://cdn.qiandaoapp.com/interior/images/3ff45be24f8686698cf75886c5d235e0.svg" />
<DuIcon name="https://cdn.qiandaoapp.com/interior/images/3ff45be24f8686698cf75886c5d235e0.svg" :size="32" />
</PreviewBlock>
</template>
<script setup lang="ts">
import { DuIcon } from 'dangoui'
import { iconRefresh } from 'dangoui-icon-config'
</script>
0
所有图标
<template>
<PreviewBlock title="所有图标">
<div class="flex-auto">
<DuSearch class="mb-16px" placeholder="输入名称搜索图标..." v-model:value="keyword" />
<div class="grid grid-cols-4 gap-x-4px gap-y-8px">
<div
v-for="(iconName, idx) in displayIcons"
:key="idx"
class="flex flex-col items-center text-neutral-800"
>
<DuIcon :name="iconName" :size="32" />
<div class="mt-4px text-12px line-clamp-3 text-center text-neutral-600">{{ iconName }}</div>
</div>
</div>
</div>
</PreviewBlock>
</template>
<script setup lang="ts">
import { computed } from 'vue'
import { DuIcon, DuSearch } from 'dangoui'
import iconConfig from 'dangoui/iconfont-config.json'
const keyword = ref('')
const displayIcons = computed(() => {
return Object.keys(iconConfig.icons).filter(n => n.includes(keyword.value))
})
</script>
0
API
属性
属性名 | 类型 | 默认值 | 说明 |
---|---|---|---|
color | string | "" | 图标颜色,可以使用合法的 CSS 颜色值或者色板中具体的颜色名(如 success-solid-bg) |
ext-class | string | string[] | Record<string, boolean> | "" | |
ext-style | string | { [x: string]: string | number; } | "" | |
size | string | number | "" | 图标大小 |
name | string | "" | 图标名称,可以是内置 iconfont 的名字,也可以是图片链接 |
icon | { _: string; } | - | 内置图标,从 `dangoui-icon-config` 导入,与 name 互斥 在 web 侧必须用这个属性 |
插槽
名称 |
---|
default |
事件
名称 | 类型 |
---|---|
click | (event: "click", event: any): void |