Skip to content

警告提示 Alert

警告提示,展现需要关注的信息

何时使用

  • 当某个页面需要向用户显示警告的信息时
  • 非浮层的静态展现形式,始终展现,不会自动消失,用户可以点击关闭

基本使用

Default Text
Show Code
vue
<template>
  <Alert message="Default Text" />
</template>

不同类型

Info Text
Success Text
Warning Text
Error Text
Show Code
vue
<template>
  <Flex vertical>
    <Alert message="Info Text" type="info" />
    <Alert message="Success Text" type="success" />
    <Alert message="Warning Text" type="warning" />
    <Alert message="Error Text" type="error" />
  </Flex>
</template>

无边框

Default Text
Info Text
Success Text
Warning Text
Error Text
Show Code
vue
<template>
  <Flex vertical>
    <Alert message="Default Text" :bordered="false" />
    <Alert message="Info Text" type="info" :bordered="false" />
    <Alert message="Success Text" type="success" :bordered="false" />
    <Alert message="Warning Text" type="warning" :bordered="false" />
    <Alert message="Error Text" type="error" :bordered="false" />
  </Flex>
</template>

可关闭

Warning Text Warning Text Warning Text Warning Text Warning Text Warning Text Warning Text
Error Text
Error Description Error Description Error Description Error Description Error Description
Info Text Info Text Info Text Info Text Info Text Info Text Info Text
Success Text
Success Description Success Description Success Description Success Description
Show Code
vue
<script setup lang="ts">
function onClose (e: Event) {
  console.log(e, 'I was closed.')
}
</script>
<template>
  <Flex vertical>
    <Alert
      message="Warning Text Warning Text Warning Text Warning Text Warning Text Warning Text Warning Text"
      type="warning"
      closable
      @close="onClose"
    />
    <Alert
      message="Error Text"
      description="Error Description Error Description Error Description Error Description Error Description"
      type="error"
      closable
      @close="onClose"
    />
    <Alert
      :bordered="false"
      message="Info Text Info Text Info Text Info Text Info Text Info Text Info Text"
      type="info"
      closable
      @close="onClose"
    />
    <Alert
      :bordered="false"
      message="Success Text"
      description="Success Description Success Description Success Description Success Description"
      type="success"
      closable
      @close="onClose"
    />
  </Flex>
</template>

辅助性文字介绍

Default Text
Default Description Default Description Default Description Default Description
Success Text

Success Description Success Description Success Description

Info Text
Info Description Info Description Info Description Info Description
Warning Text
Warning Description Warning Description Warning Description Warning Description
Error Text
Error Description Error Description Error Description Error Description
Show Code
vue
<template>
  <Flex vertical>
    <Alert
      message="Default Text"
      description="Default Description Default Description Default Description Default Description"
    />
    <Alert type="success">
      Success Text
      <template #description>
        <p>
          Success Description
          <span style="color: red">Success</span>
          Description Success Description
        </p>
      </template>
    </Alert>
    <Alert
      message="Info Text"
      description="Info Description Info Description Info Description Info Description"
      type="info"
    />
    <Alert
      message="Warning Text"
      description="Warning Description Warning Description Warning Description Warning Description"
      type="warning"
    />
    <Alert
      message="Error Text"
      description="Error Description Error Description Error Description Error Description"
      type="error"
    />
  </Flex>
</template>

辅助图标

Default Tips
Success Tips
Informational Notes
Warning
Error
Default Tips
Detailed description and advices about successful copywriting.
Success Tips
Detailed description and advices about successful copywriting.
Informational Notes
Additional description and informations about copywriting.
Warning
This is a warning notice about copywriting.
Error
This is an error message about copywriting.
Show Code
vue
<script setup lang="ts">
import { AlertFilled, AlertOutlined } from '@ant-design/icons-vue'
</script>
<template>
  <Flex vertical>
    <Alert message="Default Tips" show-icon>
      <template #icon>
        <AlertFilled />
      </template>
    </Alert>
    <Alert message="Success Tips" type="success" show-icon />
    <Alert message="Informational Notes" type="info" show-icon />
    <Alert message="Warning" type="warning" show-icon />
    <Alert message="Error" type="error" show-icon />
    <Alert
      message="Default Tips"
      description="Detailed description and advices about successful copywriting."
      show-icon
    >
      <template #icon>
        <AlertOutlined />
      </template>
    </Alert>
    <Alert
      message="Success Tips"
      description="Detailed description and advices about successful copywriting."
      type="success"
      show-icon
    />
    <Alert
      message="Informational Notes"
      description="Additional description and informations about copywriting."
      type="info"
      show-icon
    />
    <Alert
      message="Warning"
      description="This is a warning notice about copywriting."
      type="warning"
      show-icon
    />
    <Alert
      message="Error"
      description="This is an error message about copywriting."
      type="error"
      show-icon
    />
  </Flex>
</template>

自定义图标

Success Tips
Informational Notes
Warning
Error
Success
Success Tips
Detailed description and advices about successful copywriting.
Informational Notes
Additional description and informations about copywriting.
Warning
This is a warning notice about copywriting.
Error
This is an error message about copywriting.
Info Tips
Detailed description and advices about successful copywriting.
Show Code
vue
<script setup lang="ts">
import { SmileOutlined } from '@ant-design/icons-vue'
</script>
<template>
  <Flex vertical>
    <Alert type="success" show-icon>
      <template #icon>
        <SmileOutlined />
      </template>
      Success Tips
    </Alert>
    <Alert type="info" show-icon>
      <template #icon>
        <SmileOutlined />
      </template>
      Informational Notes
    </Alert>
    <Alert type="warning" show-icon>
      <template #icon>
        <SmileOutlined />
      </template>
      Warning
    </Alert>
    <Alert type="error" show-icon>
      <template #icon>
        <SmileOutlined />
      </template>
      Error
    </Alert>
    <Alert type="success" show-icon>
      <template #icon>
        <Avatar size="small" src="https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/1.jpg" />
      </template>
      Success
    </Alert>
    <Alert
      message="Success Tips"
      description="Detailed description and advices about successful copywriting."
      type="success"
      show-icon
    >
      <template #icon>
        <smile-outlined />
      </template>
    </Alert>
    <Alert
      message="Informational Notes"
      description="Additional description and informations about copywriting."
      type="info"
      show-icon
    >
      <template #icon>
        <smile-outlined />
      </template>
    </Alert>
    <Alert message="Warning" description="This is a warning notice about copywriting." type="warning" show-icon>
      <template #icon>
        <smile-outlined />
      </template>
    </Alert>
    <Alert message="Error" description="This is an error message about copywriting." type="error" show-icon>
      <template #icon>
        <smile-outlined />
      </template>
    </Alert>
    <Alert
      message="Info Tips"
      description="Detailed description and advices about successful copywriting."
      type="info"
      show-icon
    >
      <template #icon>
        <Avatar size="large" src="https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/2.jpg" />
      </template>
    </Alert>
  </Flex>
</template>

自定义关闭文字

Info Text
Close Now
Show Code
vue
<script setup lang="ts">
function onClose (e: Event) {
  console.log(e, 'I was closed.')
}
</script>
<template>
  <Alert message="Info Text" type="info" closable close-text="Close Now" @close="onClose" />
</template>

自定义操作项

Success Tips
UNDO
Error Text
Error Description Error Description Error Description Error Description
Detail
Warning Text
Done
Info Text
Info Description Info Description Info Description Info Description
Accept
Decline
Show Code
vue
<script setup lang="ts">
function onClose (e: Event) {
  console.log(e, 'I was closed.')
}
</script>
<template>
  <Flex vertical>
    <Alert message="Success Tips" type="success" show-icon closable>
      <template #actions>
        <Button size="small" type="text">UNDO</Button>
      </template>
    </Alert>
    <Alert
      message="Error Text"
      show-icon
      description="Error Description Error Description Error Description Error Description"
      type="error"
    >
      <template #actions>
        <Button size="small" type="danger" ghost>Detail</Button>
      </template>
    </Alert>
    <Alert message="Warning Text" type="warning" closable>
      <template #actions>
        <Button size="small" type="text">Done</Button>
      </template>
    </Alert>
    <Alert
      message="Info Text"
      description="Info Description Info Description Info Description Info Description"
      type="info"
      closable
    >
      <template #actions>
        <Space vertical gap="small" align="center">
          <Button size="small" type="primary">Accept</Button>
          <Button size="small" type="danger" ghost>Decline</Button>
        </Space>
      </template>
    </Alert>
  </Flex>
</template>

APIs

Alert

参数说明类型默认值
message警告提示内容string | slotundefined
description警告提示的辅助性文字介绍string | slotundefined
type警告提示的类型'default' | 'success' | 'info' | 'warning' | 'error''default'
bordered是否显示边框booleantrue
closable是否显示关闭按钮booleanfalse
closeText自定义关闭按钮string | slotundefined
icon自定义图标,showIcontrue 时有效string | slotundefined
showIcon是否显示辅助图标booleanfalse
actions自定义操作项slotundefined

Slots

名称说明类型
default警告提示内容v-slot:default
description警告提示的辅助性文字介绍v-slot:description
closeText自定义关闭按钮v-slot:closeText
icon自定义图标v-slot:icon
actions自定义操作项v-slot:actions

Events

名称说明类型
close关闭时触发的回调函数(e: Event) => void

Released under the MIT License.