mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-29 04:46:36 +08:00
Toast
Install
import Vue from 'vue';
import { Toast } from 'vant';
Vue.use(Toast);
Usage
Text
Toast('Some messages');
Loading
Toast.loading({
message: 'Loading...',
forbidClick: true
});
Toast.loading({
message: 'Loading...',
forbidClick: true,
loadingType: 'spinner'
});
Success/Fail
Toast.success('Success');
Toast.fail('Fail');
Custom Icon
Toast({
message: 'Custom Icon',
icon: 'like-o'
});
Toast({
message: 'Custom Image',
icon: 'https://img.yzcdn.cn/vant/logo.png'
});
Update Message
const toast = Toast.loading({
duration: 0, // continuous display toast
forbidClick: true,
loadingType: 'spinner',
message: '3 seconds'
});
let second = 3;
const timer = setInterval(() => {
second--;
if (second) {
toast.message = `${second} seconds`;
} else {
clearInterval(timer);
Toast.clear();
}
}, 1000);
$toast Method
After import the Toast component, the $toast method is automatically mounted on Vue.prototype, making it easy to call within a vue component.
export default {
mounted() {
this.$toast('Some messages');
}
}
Singleton
Toast use singleton mode by default, if you need to pop multiple Toast at the same time, you can refer to the following example
Toast.allowMultiple();
const toast1 = Toast('First Toast');
const toast2 = Toast.success('Second Toast');
toast1.clear();
toast2.clear();
Set Default Options
The Toast default configuration can be globally modified with the Toast.setDefaultOptions
function.
// Set the duration of all Toast to 2000 ms
Toast.setDefaultOptions({ duration: 2000 });
// Set all loading types Toast to background unclickable
Toast.setDefaultOptions('loading', { forbidClick: true });
// Reset default options of all Toast
Toast.resetDefaultOptions();
// Reset default options of all loading Toast
Toast.resetDefaultOptions('loading');
API
Methods
Methods | Attribute | Return value | Description |
---|---|---|---|
Toast | `options | message` | toast instance |
Toast.loading | `options | message` | toast instance |
Toast.success | `options | message` | toast instance |
Toast.fail | `options | message` | toast instance |
Toast.clear | clearAll: boolean |
void |
Close toast |
Toast.allowMultiple | - | void |
Allow multlple toast at the same time |
Toast.setDefaultOptions | `type | options` | void |
Toast.resetDefaultOptions | type |
void |
Reset default options of all toasts |
Options
Attribute | Description | Type | Default | Version |
---|---|---|---|---|
type | Can be set to loading success fail html |
string | text |
- |
position | Can be set to top middle bottom |
string | middle |
- |
message | Message | string | '' |
- |
icon | Custom icon | string | - | 2.0.1 |
iconPrefix | Icon className prefix | string | van-icon |
2.0.9 |
overlay | Whether to show overlay | boolean | false |
2.2.13 |
forbidClick | Whether to forbid click background | boolean | false |
- |
closeOnClick | Whether to close after clicked | boolean | false |
2.1.5 |
closeOnClickOverlay | Whether to close when click overlay | boolean | false |
2.2.13 |
loadingType | Loading icon type, can be set to spinner |
string | circular |
- |
duration | Toast duration(ms), won't disappear if value is 0 | number | 2000 |
- |
className | Custom className | any | - | - |
onOpened | Callback function after opened | Function | - | - |
onClose | Callback function after close | Function | - | - |
transition | Transition, equivalent to name prop of transtion |
string | - | 2.2.6 |
getContainer | Return the mount node for Toast | string | () => Element | body |
- |