57 lines
1.4 KiB
Vue
57 lines
1.4 KiB
Vue
<docs>
|
||
---
|
||
order: 4
|
||
title:
|
||
zh-CN: 加载中状态
|
||
en-US: Loading
|
||
---
|
||
|
||
## zh-CN
|
||
|
||
添加 `loading` 属性即可让按钮处于加载状态,最后两个按钮演示点击后进入加载状态。
|
||
|
||
## en-US
|
||
|
||
A loading indicator can be added to a button by setting the `loading` property on the `Button`.
|
||
</docs>
|
||
|
||
<template>
|
||
<a-space direction="vertical">
|
||
<a-space>
|
||
<a-button type="primary" loading>Loading</a-button>
|
||
<a-button type="primary" size="small" loading>Loading</a-button>
|
||
</a-space>
|
||
<a-space>
|
||
<a-button type="primary" :loading="loading" @mouseenter="loading = true">
|
||
mouseenter me!
|
||
</a-button>
|
||
<a-button type="primary" :loading="iconLoading" @click="enterIconLoading">
|
||
<template #icon><PoweroffOutlined /></template>
|
||
延迟1s
|
||
</a-button>
|
||
</a-space>
|
||
<a-space>
|
||
<a-button type="primary" loading />
|
||
<a-button type="primary" shape="circle" loading />
|
||
<a-button danger shape="round" loading />
|
||
</a-space>
|
||
</a-space>
|
||
</template>
|
||
<script lang="ts" setup>
|
||
import { ref } from 'vue';
|
||
import { PoweroffOutlined } from '@ant-design/icons-vue';
|
||
|
||
interface DelayLoading {
|
||
delay: number;
|
||
}
|
||
const loading = ref<boolean>(false);
|
||
const iconLoading = ref<boolean | DelayLoading>(false);
|
||
const enterIconLoading = () => {
|
||
iconLoading.value = { delay: 1000 };
|
||
|
||
setTimeout(() => {
|
||
iconLoading.value = false;
|
||
}, 6000);
|
||
};
|
||
</script>
|