mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-20 18:54:24 +00:00 
			
		
		
		
	 ffa3fddfae
			
		
	
	ffa3fddfae
	
	
	
		
			
			* fix: Tabbar icon line-height * [new feature] progress add showPivot prop * [new feature] TabItem support vue-router * [new feature] update document header style * [Doc] add toast english ducoment * [bugfix] Search box-sizing wrong * [Doc] update vant-demo respo * [Doc] translate theme & demo pages * [Doc] add Internationalization document * [bugfix] remove unnecessary props
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <demo-section>
 | |
|     <demo-block :title="$t('title1')">
 | |
|       <van-button @click="showToast">{{ $t('title1') }}</van-button>
 | |
|     </demo-block>
 | |
| 
 | |
|     <demo-block :title="$t('title2')">
 | |
|       <van-button @click="showLoadingToast">{{ $t('title2') }}</van-button>
 | |
|     </demo-block>
 | |
| 
 | |
|     <demo-block :title="$t('title3')">
 | |
|       <van-button @click="showSuccessToast">{{ $t('success') }}</van-button>
 | |
|       <van-button @click="showFailToast">{{ $t('fail') }}</van-button>
 | |
|     </demo-block>
 | |
| 
 | |
|     <demo-block :title="$t('advancedUsage')">
 | |
|       <van-button @click="showCustomizedToast">{{ $t('advancedUsage') }}</van-button>
 | |
|     </demo-block>
 | |
|   </demo-section>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|   i18n: {
 | |
|     'zh-CN': {
 | |
|       title1: '文字提示',
 | |
|       title2: '加载提示',
 | |
|       title3: '成功/失败提示',
 | |
|       success: '成功提示',
 | |
|       fail: '失败提示',
 | |
|       text1: '我是提示文案,建议不超过十五字~',
 | |
|       text2: '成功文案',
 | |
|       text3: '失败文案',
 | |
|       text4: second => `倒计时 ${second} 秒`
 | |
|     },
 | |
|     'en-US': {
 | |
|       title1: 'Text',
 | |
|       title2: 'Loading',
 | |
|       title3: 'Success/Fail',
 | |
|       success: 'Success',
 | |
|       fail: 'Fail',
 | |
|       text1: 'Some messages',
 | |
|       text2: 'Success',
 | |
|       text3: 'Fail',
 | |
|       text4: second => `${second} seconds`
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   methods: {
 | |
|     showToast() {
 | |
|       Toast(this.$t('text1'));
 | |
|     },
 | |
| 
 | |
|     showLoadingToast() {
 | |
|       Toast.loading({ mask: true });
 | |
|     },
 | |
| 
 | |
|     showSuccessToast() {
 | |
|       Toast.success(this.$t('text2'));
 | |
|     },
 | |
| 
 | |
|     showFailToast() {
 | |
|       Toast.fail(this.$t('text3'));
 | |
|     },
 | |
| 
 | |
|     showCustomizedToast(duration) {
 | |
|       const toast = Toast.loading({
 | |
|         duration: 0,
 | |
|         forbidClick: true,
 | |
|         message: this.$t('text4', 3)
 | |
|       });
 | |
| 
 | |
|       let second = 3;
 | |
|       const timer = setInterval(() => {
 | |
|         second--;
 | |
|         if (second) {
 | |
|           toast.message = this.$t('text4', second);
 | |
|         } else {
 | |
|           clearInterval(timer);
 | |
|           Toast.clear();
 | |
|         }
 | |
|       }, 1000);
 | |
|     }
 | |
|   }
 | |
| };
 | |
| </script>
 | |
| 
 | |
| 
 | |
| <style lang="postcss">
 | |
| .demo-toast {
 | |
|   .van-button {
 | |
|     margin-left: 15px;
 | |
|   }
 | |
| }
 | |
| </style>
 |