vue+vant组件实现上拉加载(分页)

本文介绍了使用Vue.js如何通过API接口实现一个动态加载列表的内容,包括列表渲染、分页控制和防抖机制,确保性能优化。
摘要由CSDN通过智能技术生成
<van-list
	v-model:loading="loading"
	:offset="30"
	:finished="finished"
	finished-text="没有更多了"
	@load="onLoad"
>
	<div v-for="(item, index) in data.list" class="record-list" :key="index">
		<p>{{item.title}}</p>	
	</div>
</van-list>

<script setup lang="ts">
import { reactive, onMounted } from 'vue'
import { getPlayBackList} from '@/api/modules/directSeeding'

const data = reactive({
	list: [] as any,
})
const loading:any = ref(true)
const finished:any = ref(false)
const page:any = ref(1)
const pageSize:any = ref(6)


//调接口获取数据
const getlist = () => {
    //接口
	getPlayBackList(
		pageNumber: page.value,
		pageSize: pageSize.value
	}).then((res: any) => {
		data.list.push(...res.data.data)
		loading.value = false
		loadingTwo.value = false
		finished.value = res.data.data.length < pageSize.value
	})
}

//防抖
const delay = (() => {
	let timer: any = 0
	return (callback: any, ms: any) => {
		clearTimeout(timer)
		timer = setTimeout(callback, ms)
	}
})()

// 上拉加载
const onLoad = () => {
	delay(() => {
		page.value += 1
		getlist()
	}, 1000)
}
onMounted(() => {
	getlist()
})
</script>

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值