1
0
mirror of https://gitee.com/vant-contrib/vant.git synced 2025-04-06 03:57:59 +08:00
2020-12-13 19:15:07 +08:00

164 lines
3.5 KiB
Vue

<template>
<van-tabs>
<van-tab :title="t('basicUsage')">
<van-list
v-model:loading="list[0].loading"
:finished="list[0].finished"
:finished-text="t('finishedText')"
@load="onLoad(0)"
>
<van-cell v-for="item in list[0].items" :key="item" :title="item" />
</van-list>
</van-tab>
<van-tab :title="t('errorInfo')">
<van-list
v-model:loading="list[1].loading"
v-model:error="list[1].error"
:finished="list[1].finished"
:error-text="t('errorText')"
@load="onLoad(1)"
>
<van-cell v-for="item in list[1].items" :key="item" :title="item" />
</van-list>
</van-tab>
<van-tab :title="t('pullRefresh')">
<van-pull-refresh v-model="list[2].refreshing" @refresh="onRefresh(2)">
<van-list
v-model:loading="list[2].loading"
:finished="list[2].finished"
:finished-text="t('finishedText')"
@load="onLoad(2)"
>
<van-cell v-for="item in list[2].items" :key="item" :title="item" />
</van-list>
</van-pull-refresh>
</van-tab>
</van-tabs>
</template>
<script lang="ts">
import { reactive, toRefs } from 'vue';
import { useTranslate } from '@demo/use-translate';
const i18n = {
'zh-CN': {
errorInfo: '错误提示',
errorText: '请求失败,点击重新加载',
pullRefresh: '下拉刷新',
finishedText: '没有更多了',
},
'en-US': {
errorInfo: 'Error Info',
errorText: 'Request failed. Click to reload',
pullRefresh: 'PullRefresh',
finishedText: 'Finished',
},
};
export default {
setup() {
const t = useTranslate(i18n);
const state = reactive({
list: [
{
items: [] as string[],
refreshing: false,
loading: false,
error: false,
finished: false,
},
{
items: [] as string[],
refreshing: false,
loading: false,
error: false,
finished: false,
},
{
items: [] as string[],
refreshing: false,
loading: false,
error: false,
finished: false,
},
],
});
const onLoad = (index: number) => {
const list = state.list[index];
list.loading = true;
setTimeout(() => {
if (list.refreshing) {
list.items = [];
list.refreshing = false;
}
for (let i = 0; i < 10; i++) {
const text = list.items.length + 1;
list.items.push(text < 10 ? '0' + text : String(text));
}
list.loading = false;
list.refreshing = false;
// show error info in second demo
if (index === 1 && list.items.length === 10 && !list.error) {
list.error = true;
} else {
list.error = false;
}
if (list.items.length >= 40) {
list.finished = true;
}
}, 1000);
};
const onRefresh = (index: number) => {
state.list[index].finished = false;
onLoad(index);
};
return {
...toRefs(state),
t,
onLoad,
onRefresh,
};
},
};
</script>
<style lang="less">
@import '../../style/var';
.demo-list {
.van-cell {
text-align: center;
}
.page-desc {
margin: 0;
padding: 5px 0;
color: @gray-7;
font-size: 14px;
text-align: center;
&--text {
margin: 0;
}
&--option {
margin: 12px;
}
}
.van-checkbox__label {
color: @gray-7;
}
}
</style>