vant 中的SwipeCell踩坑 onLoad 不触发的问题 List 列表 上拉加载

最近我咋做H5移动端的时候,用了一个新的框架 vant 在使用后感觉还是可以的 但是我在做分页加载的时候遇到一个坑 就是用到了框架中是上拉加载 《 List 列表 》

问题复现

   <van-list v-model="loading" :finished="finished" finished-text="没有更多了" @load="onLoad">
			<van-cell v-for="item in list" :key="item" :title="item" />
	</van-list>

根据文档提示 在内容会触发在到达底部的时候会触发 onLoad 在这里插入图片描述
需要注意的是这句话 触发onLoad的时候回将loading设置成true 《但是你没告诉我onLoad这玩意你上来就触发啊》

所以导致就是我们的onLoad 当页面明明滑到底了就是不触发

这时loading是=true的 所以不会去触发onLoad

解决办法

        在我的们的 onLoad  事件中加上  ‘ this.loading = false’ 

在这里插入图片描述

这时就会触发onLoad 了

如果vue3 vant list 组件触发上拉加载onLoad事件,可能是以下原因: 1. 没有设置List组件的高度属性。 在List组件中,必须设置height属性,否则无法触发上拉加载功能。你可以设置一个固定的高度或者一个动态计算的高度,例如: ``` <van-list :height="500" @load="onLoad"></van-list> ``` 2. 没有设置List组件的loading属性。 loading属性是用来控制上拉加载的状态的,如果没有设置loading属性,上拉加载功能将无法正常工作。你可以在setup中定义一个ref变量来控制loading属性,例如: ``` <template> <van-list :height="500" :loading="loading" @load="onLoad"></van-list> </template> <script> import { ref } from 'vue'; export default { setup() { const loading = ref(false); const onLoad = () => { loading.value = true; // ... }; return { loading, onLoad, }; }, }; </script> ``` 3. 没有在List组件上绑定@load事件。 上拉加载触发需要依赖@load事件,如果没有在List组件上绑定该事件,上拉加载功能将无法正常工作。你可以在List组件上绑定一个方法,例如: ``` <template> <van-list :height="500" :loading="loading" @load="onLoad"></van-list> </template> <script> import { ref } from 'vue'; export default { setup() { const loading = ref(false); const onLoad = () => { loading.value = true; // ... }; return { loading, onLoad, }; }, }; </script> ``` 如果以上方法都没有解决问题,你可以尝试检查控制台输出,查看是否有相关的错误信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值