使用Vant框架list组件遇到的坑

介绍

Vant 是有赞前端团队开源的移动端组件库,于 2017 年开源,已持续维护 4 年时间。Vant 对内承载了有赞所有核心业务,对外服务十多万开发者,是业界主流的移动端组件库之一。

特性

提供 60 多个高质量组件,覆盖移动端各类场景
性能极佳,组件平均体积不到 1kb(min+gzip)
单元测试覆盖率 90%+,提供稳定性保障
完善的中英文文档和示例
支持 Vue 2 & Vue 3
支持按需引入
支持主题定制
支持国际化
支持 TypeScript
支持 SSR

快速配置和具体介绍请去官方文档,Vant框架在Github上点赞众多,用起来发现还是很好用的,强力推荐

官方文档:https://vant-contrib.gitee.io/vant/#/zh-CN/home

今天就聊一下使用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>

export default {
  data() {
    return {
      list: [],
      loading: false,
      finished: false,
    };
  },
  methods: {
    onLoad() {
      // 异步更新数据
      // setTimeout 仅做示例,真实场景中一般为 ajax 请求
      setTimeout(() => {
        for (let i = 0; i < 10; i++) {
          this.list.push(this.list.length + 1);
        }

        // 加载状态结束
        this.loading = false;

        // 数据全部加载完成
        if (this.list.length >= 40) {
          this.finished = true;
        }
      }, 1000);
    },
  },
};

效果图片:在这里插入图片描述

可是!你复制代码,发现,发现完全不好用!这个定时任务简直看不懂,触底加载简直毫无逻辑,通过几个小时的研究,发现问题所在居然是CSS!对,你没有听错!是CSS导致的!

下方代码,重点看css部分,JS部分,记住settimeout不要去掉,不要相信他的注释,业务写在settimeout里就可以了
解释一下这个css的含义,就是van-list需要给他定义一个高度,并且滚动自适应,这样在不填满高度或者是滚动触底的时候就可以完美的触发onLoad时间了,这里还有一个重点!就是van-list的父级也要定义一下高度,不然也是不行的!
至于业务一定要在settimeout中写业务才能有效,了解的大佬看到了帮忙解释一下,不是很明白

<div class="txtc" style="height: 100%; position: fixed; width: 100%">
	<van-list style="height:100%;width:100%;overflow-y:auto;"
	        v-model="loading"
	        :finished="finished"
	        finished-text="没有更多了"
	        @load="onLoad"
	      >
	        <div class="divinfo" v-for="item in tableData" :key="item.sid"></div>
	</van-list>
</div>
使用 VantList 组件时,如果连续触发带有异步操作的事件,可能会导致一些问题。为了解决这个问题,你可以考虑使用节流(throttling)或者防抖(debouncing)的技术。 节流(throttling)是指在一段时间内只执行一次函数。你可以通过在事件处理函数中使用一个计时器,设置一个时间间隔,在这个时间间隔内只执行一次函数。这样可以避免频繁触发事件。 防抖(debouncing)是指在某个事件连续触发后,只执行最后一次触发的函数。你可以在事件处理函数中设置一个计时器,在一定的时间间隔内,如果事件再次触发,就清除之前的计时器,并重新设置一个新的计时器。这样可以确保只执行最后一次触发的函数。 具体实现方式可以根据你使用框架或者库来选择相应的节流或者防抖函数。例如,如果你使用 Vue.js,可以使用 Lodash 库提供的 `throttle` 或者 `debounce` 函数来实现节流或者防抖。 以下是一个使用 Lodash 的 `debounce` 函数的示例: ```javascript import { debounce } from 'lodash'; // 在组件中定义一个 debounced 函数 methods: { handleEvent: debounce(function() { // 处理事件逻辑 }, 300) // 设置延迟时间 } ``` 这样,当事件连续触发时,只会执行最后一次触发的函数,并且在延迟时间内不会重复执行。 希望以上解决方案能够帮助你解决连续触发问题!如果还有其他问题,请随时提问。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值