需求:拉下菜单数据过多,200条以上,就会导致select组件卡死。所以需要使用滑动到底部使其分页加载

    可以借助 onPopupScroll 事件监听下拉菜单滚动事件,并判断当前是否已经到达了下拉菜单底部。具体可以通过以下步骤实现

    1、在组件中绑定 @popupScroll回调事件

 <a-select
                v-model="Form.governmentDirectors"
                @popupScroll="handlePopupScroll"
              >
                <a-select-option
                  v-for="i in queryPageData"
                  :value="i.id"
                  :key="i.id"
                  &gt;{{ i.fullName }}</a-select-option
                &gt;
              </a-select&gt;

    2、在事件处理函数中,获取当前dom节点下滑的距离滚动位置

handlePopupScroll(e) {
  const { target } = e;
  const { scrollTop, scrollHeight, clientHeight } = target;

  if (scrollTop + clientHeight == scrollHeight) {
    // 已经到达底部,触发分页逻辑
    // todo 这里可以触发加载下一页请求  具体函数根据当前业务需求来定
    handlePagination();
  }
}

    分页逻辑例子:主要是页码++,数据追加(concat

querypageFn() {
      const params = {
        page: this.querypage.page,
        size: this.querypage.size
      }
      queryListPage(params).then((res) => {
        if (res.data.code === 0) {
          if (res.data.data.length === 0) {
            return
          } else {
            this.queryPageData = this.queryPageData.concat(res.data.data)
          }
        }
      })
    },

    以上基本实现了使用a-select下拉框组件实现下拉分页加载数据,下面我们来说一下我遇到的坑。

浏览器大小缩放为正常100%是没有问题的,可以正常下拉

并且打印scrollTop, scrollHeight, clientHeight三个属性的关系

    但是当浏览器缩放大小调整不是100%后 我们下拉框滑到底部,是不会继续请求的,这时控制台没有报错接口返回没有什么问题

console.log(scrollHeight, scrollTop, clientHeight, 'llslsl')

以下为打印内容 分辨率为125%的时候,我们发现 scrollTop发现偏差,导致条件等式不成立

    到现在我就彻底慌了,难道scrollTop属性浏览器分辨率有关。查阅资料后还真的是。

可以这样解释:当分辨率发生变化时,页面布局尺寸也会发生相应的变化,导致元素位置大小产生了变化。而 e.target 是指触发事件元素,在这个元素尺寸位置发生变化之后,它的 scrollTop 属性自然也会受到影响

具体地说,当元素高度变大或缩小时,它的内容区域的总高度也会发生相应的变化,进而影响scrollTop 属性的值。例如,当元素高度变大时,它的内容需要滚动更多的距离才能到达顶部,因此 scrollTop 属性的值也会相应地增大;而当元素高度变小时,则需要滚动更少的距离才能到达顶部,因此 scrollTop 属性的值也会相应地减小。

以上是分辨率变化对 e.targetscrollTop 属性的影响一个粗略解释需要注意的是,具体的影响还取决于其他因素,如CSS样式、页面结构因素的变化。如果具体情况下需要深入了解 e.targetscrollTop 属性是如何受到影响的,可以通过调试工具等手段进行进一步排查分析

    说一下解决方案吧,我发现无论怎么变大变小  scrollTop 的偏差都会在2以内。所以我们需要改一下if判断里面判断方式

if (scrollTop + 2 + offsetHeight >= scrollHeight) 

    以上我们手动给他把这个偏差加上2,并且把等式换为大于等于,我们就能完美解决bug,我一开始以为是歪点子,现在总结之后发现这是一个合适解决方案哦!

原文地址:https://blog.csdn.net/weixin_44948981/article/details/130259646

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_15293.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注