mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-05 19:41:42 +08:00
3.7 KiB
3.7 KiB
PullRefresh
Install
import { createApp } from 'vue';
import { PullRefresh } from 'vant';
const app = createApp();
app.use(PullRefresh);
Usage
Basic Usage
The refresh
event will be Emitted when pull refresh, you should set v-model
to false
to reset loading status after process refresh event.
<van-pull-refresh v-model="state.loading" @refresh="onRefresh">
<p>Refresh Count: {{ state.count }}</p>
</van-pull-refresh>
import { reactive } from 'vue';
import { Toast } from 'vant';
export default {
setup() {
const state = reactive({
count: 0,
loading: false,
});
const onRefresh = () => {
setTimeout(() => {
Toast('Refresh Success');
state.loading = false;
state.count++;
}, 1000);
};
return {
state,
onRefresh,
};
},
};
Success Tip
Use success-text
to set the success prompt after the refresh is successful
<van-pull-refresh
v-model="isLoading"
success-text="Refresh success"
@refresh="onRefresh"
>
<p>Refresh Count: {{ count }}</p>
</van-pull-refresh>
Custom Tips
Use slots to custom tips.
<van-pull-refresh v-model="isLoading" :head-height="80" @refresh="onRefresh">
<template #pulling="props">
<img
class="doge"
src="https://img.yzcdn.cn/vant/doge.png"
:style="{ transform: `scale(${props.distance / 80})` }"
/>
</template>
<template #loosing>
<img class="doge" src="https://img.yzcdn.cn/vant/doge.png" />
</template>
<template #loading>
<img class="doge" src="https://img.yzcdn.cn/vant/doge-fire.jpg" />
</template>
<p>Refresh Count: {{ count }}</p>
</van-pull-refresh>
<style>
.doge {
width: 140px;
height: 72px;
margin-top: 8px;
border-radius: 4px;
}
</style>
API
Props
Attribute | Description | Type | Default |
---|---|---|---|
v-model | Loading status | boolean | - |
pulling-text | Text to show when pulling | string | Pull to refresh... |
loosing-text | Text to show when loosing | string | Loose to refresh... |
loading-text | Text to show when loading | string | Loading... |
success-text | Text to show when loading success | string | - |
success-duration | Success text display duration(ms) | number | string | 500 |
animation-duration | Animation duration | number | string | 300 |
head-height | Height of head | number | string | 50 |
pull-distance v3.0.8 |
The distance to trigger the pull refresh | number | string | same as head-height |
disabled | Whether to disable pull refresh | boolean | false |
Events
Event | Description | Parameters |
---|---|---|
refresh | Emitted after pulling refresh | - |
Slots
Name | Description | SlotProps |
---|---|---|
default | Default slot | - |
normal | Content of head when at normal status | - |
pulling | Content of head when at pulling | { distance } |
loosing | Content of head when at loosing | { distance } |
loading | Content of head when at loading | { distance } |
success | Content of head when succeed | - |
Less Variables
How to use: Custom Theme.
Name | Default Value | Description |
---|---|---|
@pull-refresh-head-height | 50px |
- |
@pull-refresh-head-font-size | @font-size-md |
- |
@pull-refresh-head-text-color | @gray-6 |
- |