Skip to content

标签 Tag

进行标记和分类的小标签

何时使用

  • 用于标记事物的属性和维度
  • 进行分类

基本使用

Tag 1
Tag 2
Show Code
vue
<script setup lang="ts">
const onClose = (e: MouseEvent) => {
  console.log(e)
}
</script>
<template>
  <Space gap="small">
    <Tag>Tag 1</Tag>
    <Tag><a href="https://blog.csdn.net/Dandrose">Link</a></Tag>
    <Tag closable @close="onClose">Tag 2</Tag>
  </Space>
</template>

多彩标签

pink
red
yellow
orange
cyan
green
blue
purple
geekblue
magenta
volcano
gold
lime


#f50
#2db7f5
#87d068
#108ee9
Show Code
vue
<template>
  <Space gap="small">
    <Tag color="pink">pink</Tag>
    <Tag color="red">red</Tag>
    <Tag color="yellow">yellow</Tag>
    <Tag color="orange">orange</Tag>
    <Tag color="cyan">cyan</Tag>
    <Tag color="green">green</Tag>
    <Tag color="blue">blue</Tag>
    <Tag color="purple">purple</Tag>
    <Tag color="geekblue">geekblue</Tag>
    <Tag color="magenta">magenta</Tag>
    <Tag color="volcano">volcano</Tag>
    <Tag color="gold">gold</Tag>
    <Tag color="lime">lime</Tag>
  </Space>
  <br/>
  <br/>
  <Space gap="small">
    <Tag color="#f50">#f50</Tag>
    <Tag color="#2db7f5">#2db7f5</Tag>
    <Tag color="#87d068">#87d068</Tag>
    <Tag color="#108ee9">#108ee9</Tag>
  </Space>
</template>

预设状态的标签

Without icon
success
processing
error
warning
default
With icon
success
processing
error
warning
waiting
stop
😉 blink
Show Code
vue
<script setup lang="ts">
import {
  CheckCircleOutlined,
  SyncOutlined,
  CloseCircleOutlined,
  ExclamationCircleOutlined,
  ClockCircleOutlined,
  MinusCircleOutlined
} from '@ant-design/icons-vue'
</script>
<template>
  <Divider orientation="left">Without icon</Divider>
  <Space gap="small">
    <Tag color="success">success</Tag>
    <Tag color="processing">processing</Tag>
    <Tag color="error">error</Tag>
    <Tag color="warning">warning</Tag>
    <Tag color="default">default</Tag>
  </Space>
  <Divider orientation="left">With icon</Divider>
  <Space gap="small">
    <Tag color="success">
      <template #icon>
        <CheckCircleOutlined />
      </template>
      success
    </Tag>
    <Tag color="processing">
      <template #icon>
        <SyncOutlined spin />
      </template>
      processing
    </Tag>
    <Tag color="error">
      <template #icon>
        <CloseCircleOutlined />
      </template>
      error
    </Tag>
    <Tag color="warning">
      <template #icon>
        <ExclamationCircleOutlined />
      </template>
      warning
    </Tag>
    <Tag color="default">
      <template #icon>
        <ClockCircleOutlined />
      </template>
      waiting
    </Tag>
    <Tag color="default">
      <template #icon>
        <MinusCircleOutlined />
      </template>
      stop
    </Tag>
    <Tag color="default" icon="😉">
      blink
    </Tag>
  </Space>
</template>

图标按钮标签

Apple
Twitter
Youtube
Instagram
Show Code
vue
<script setup lang="ts">
import {
  AppleOutlined,
  TwitterOutlined,
  YoutubeOutlined,
  InstagramOutlined
} from '@ant-design/icons-vue'
</script>
<template>
  <Space gap="small">
    <Tag color="#cd853f">
      <template #icon>
        <AppleOutlined />
      </template>
      Apple
    </Tag>
    <Tag color="#55acee">
      <template #icon>
        <TwitterOutlined />
      </template>
      Twitter
    </Tag>
    <Tag color="#cd201f">
      <template #icon>
        <YoutubeOutlined />
      </template>
      Youtube
    </Tag>
    <Tag color="#3b5999">
      <template #icon>
        <InstagramOutlined />
      </template>
      Instagram
    </Tag>
  </Space>
</template>

动态添加和删除

使用字符串格式数组


天空
大海
湖泊
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import type { TagItem } from 'vue-amazing-ui'
const strTags = ref<string[]>(['天空', '大海', '湖泊'])
watchEffect(() => {
  console.log('strTags', strTags.value)
})
const onDynamicClose = (item: TagItem, index: number) => {
  console.log('item', item)
  console.log('index', index)
}
</script>
<template>
  <Space gap="small">
    <Tag dynamic v-model:value="strTags" @dynamic-close="onDynamicClose" />
  </Space>
</template>

使用对象格式数组


天空
大海 1
湖泊
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import { CheckCircleOutlined } from '@ant-design/icons-vue'
import type { TagItem } from 'vue-amazing-ui'
const objTags = ref<TagItem[]>([
  {
    label: '天空',
    color: 'processing'
  },
  {
    label: '大海',
    closable: false,
    color: 'error'
  },
  {
    label: '湖泊',
    color: 'pink'
  }
])
watchEffect(() => {
  console.log('objTags', objTags.value)
})
const onDynamicClose = (item: TagItem, index: number) => {
  console.log('item', item)
  console.log('index', index)
}
</script>
<template>
  <Space gap="small">
    <Tag dynamic v-model:value="objTags" @dynamic-close="onDynamicClose">
      <template #label="{ label, index }">
        <template v-if="index===1">
          {{ label }} {{ index }}
        </template>
      </template>
      <template #icon="{ index }">
        <template v-if="index===0">
          <CheckCircleOutlined />
        </template>
      </template>
    </Tag>
  </Space>
</template>

三种尺寸

爱在西元前
超人不会飞
天空
大海
湖泊
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import type { TagItem } from 'vue-amazing-ui'
const strTags = ref<string[]>(['天空', '大海', '湖泊'])
watchEffect(() => {
  console.log('strTags', strTags.value)
})
const onClose = (e: MouseEvent) => {
  console.log('e', e)
}
const onDynamicClose = (item: TagItem, index: number) => {
  console.log('item', item)
  console.log('index', index)
}
</script>
<template>
  <Space gap="small">
    <Tag closable size="small" @close="onClose">
      爱在西元前
    </Tag>
    <Tag color="warning" closable @close="onClose">
      超人不会飞
    </Tag>
    <Tag
      color="blue"
      size="large"
      dynamic
      v-model:value="strTags"
      closable
      @close="onDynamicClose" />
  </Space>
</template>

自定义动态标签排列

天空
大海
湖泊
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import type { TagItem } from 'vue-amazing-ui'
const strTags = ref<string[]>(['天空', '大海', '湖泊'])
watchEffect(() => {
  console.log('strTags', strTags.value)
})
const onDynamicClose = (item: TagItem, index: number) => {
  console.log('item', item)
  console.log('index', index)
}
</script>
<template>
  <Tag
    closable
    dynamic
    color="blue"
    size="large"
    :space-props="{ vertical: true, gap: 12 }"
    v-model:value="strTags"
    @close="onDynamicClose"
  />
</template>

无边框

Tag 1
Tag 2
Tag 3
Tag 4
processing
success
error
warning
magenta
red
volcano
orange
gold
lime
green
cyan
blue
geekblue
purple
Show Code
vue
<template>
  <Space gap="small">
    <Tag :bordered="false">Tag 1</Tag>
    <Tag :bordered="false">Tag 2</Tag>
    <Tag :bordered="false" closable>Tag 3</Tag>
    <Tag :bordered="false" closable>Tag 4</Tag>
  </Space>
  <Divider />
  <Space gap="small">
    <Tag :bordered="false" color="processing">processing</Tag>
    <Tag :bordered="false" color="success">success</Tag>
    <Tag :bordered="false" color="error">error</Tag>
    <Tag :bordered="false" color="warning">warning</Tag>
    <Tag :bordered="false" color="magenta">magenta</Tag>
    <Tag :bordered="false" color="red">red</Tag>
    <Tag :bordered="false" color="volcano">volcano</Tag>
    <Tag :bordered="false" color="orange">orange</Tag>
    <Tag :bordered="false" color="gold">gold</Tag>
    <Tag :bordered="false" color="lime">lime</Tag>
    <Tag :bordered="false" color="green">green</Tag>
    <Tag :bordered="false" color="cyan">cyan</Tag>
    <Tag :bordered="false" color="blue">blue</Tag>
    <Tag :bordered="false" color="geekblue">geekblue</Tag>
    <Tag :bordered="false" color="purple">purple</Tag>
  </Space>
</template>

APIs

Tag

参数说明类型默认值
closable标签是否可以关闭booleanfalse
color标签颜色,预置多种常用颜色:'success', 'processing', 'error', 'warning', 'pink', 'red', 'yellow', 'orange', 'cyan', 'green', 'blue', 'purple', 'geekblue', 'magenta', 'volcano', 'gold', 'lime'stringundefined
icon设置图标string | slotundefined
size标签尺寸'small' | 'middle' | 'large''middle'
bordered是否有边框booleantrue
dynamic是否启用标签动态添加和删除booleanfalse
spacePropsSpace 组件属性配置,参考 Space Props ,仅当 dynamic: true 时生效object{}
value
v-model
动态标签数组,仅当 dynamic: true 时生效string[] | Item[][]

Item Type

名称说明类型默认值
label?标签文本string | slotundefined
closable?标签是否可以关闭booleantrue
color?标签颜色stringundefined
icon?设置图标string | slotundefined
size?标签尺寸'small' | 'middle' | 'large''middle'
bordered?是否有边框booleantrue

Slots

名称说明类型
icon自定义图标v-slot:icon="{ item, icon, index }"
label自定义标签文本v-slot:label="{ item, label, index }"
default自定义内容v-slot:default

Events

名称说明类型
close关闭时的回调(e: Event) => void
dynamicClose启用标签动态添加和删除时关闭的回调(item: Item, index: number) => void

Released under the MIT License.