55 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.3 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-button type="primary" loading>Loading</a-button>
 | ||
|   <a-button type="primary" size="small" loading>Loading</a-button>
 | ||
|   <br />
 | ||
|   <a-button type="primary" :loading="loading" @mouseenter="loading = true">mouseenter me!</a-button>
 | ||
|   <a-button type="primary" icon="poweroff" :loading="iconLoading" @click="enterIconLoading">
 | ||
|     延迟1s
 | ||
|   </a-button>
 | ||
|   <br />
 | ||
|   <a-button type="primary" loading />
 | ||
|   <a-button type="primary" shape="circle" loading />
 | ||
|   <a-button danger shape="round" loading />
 | ||
| </template>
 | ||
| <script lang="ts">
 | ||
| import { defineComponent, ref } from 'vue';
 | ||
| 
 | ||
| interface DelayLoading {
 | ||
|   delay: number;
 | ||
| }
 | ||
| export default defineComponent({
 | ||
|   setup() {
 | ||
|     const iconLoading = ref<boolean | DelayLoading>(false);
 | ||
|     const enterIconLoading = () => {
 | ||
|       iconLoading.value = { delay: 1000 };
 | ||
| 
 | ||
|       setTimeout(() => {
 | ||
|         iconLoading.value = false;
 | ||
|       }, 6000);
 | ||
|     };
 | ||
|     return {
 | ||
|       loading: ref(false),
 | ||
|       iconLoading,
 | ||
|       enterIconLoading,
 | ||
|     };
 | ||
|   },
 | ||
| });
 | ||
| </script>
 |