【全栈开发指南】自定义AntDesignVue Select标签实现懒加载分页

实现懒加载分页的目的是优化网页加载速度和用户体验。传统的分页方式需要用户点击"下一页"才能加载下一页的内容,这种方式会导致用户等待时间过长,严重影响用户体验。而懒加载分页可以在用户滚动到页面底部时自动加载下一页的内容,避免了用户的等待时间和页面的重新刷新,提高了用户的操作流畅性和满意度。此外,懒加载分页还可以减少页面资源的加载量,提高页面加载速度,减轻服务器压力。因此,实现懒加载分页可以有效提升网页的性能和用户体验。

懒加载分页的实现原理可以简单概括为:当用户滚动页面时,加载下一页数据。具体实现流程如下:

1.页面加载时,只加载第一页数据,其他数据不显示。

2.当用户向下滚动页面时,判断当前页面是否已滚动到了页面底部。

3.如果滚动到了页面底部,就发起异步请求,请求下一页数据。

4.等待数据返回后,将数据添加到页面中,继续等待用户滚动事件的触发。

5.重复上述过程,直到数据加载完毕或用户停止滚动页面。

实际业务需求中,当下拉框需要显示的选项过多时,我们需要实现懒加载分页。要在Ant Design Vue中自定义Select标签并实现懒加载分页,我们这里使用添加滚动监听,当下拉框滚动到底部时加载分页数据,来实现懒加载分页。

  1. 首先,在a-select组件配置@popupScroll,该方法用于处理懒加载和分页逻辑,动态更新a-select-option。

    复制代码
             <a-select
                 :value="selectedVal"
                 placeholder="请选择数据源"
                 allow-clear
                 show-search
                 :filter-option="false"
                 @popupScroll="handlePopupScroll"
                 @search="filterOpts"
                 @change="clickLdapOpt"
                 :not-found-content="null">
                 <a-select-option v-for="item in datasourceList" :key="item.id" :value="item.id">
                   {{ item.datasourceName }}
                 </a-select-option>
            </a-select>
  2. 定义分页参数,在分页时标识当前页数和每页条数等。

    复制代码
                 // 获取数据源搜索的查询条件
                 selectedVal: undefined, // select组件绑定的value值
                 pageNo: 1, // 当前加载的页数
                 pageSize: 10, // 每页加载的数据个数
                 datasourceCount: 0, // 服务器返回的响应信息
                 datasourceList: [], // 服务器返回的响应信息中的搜索匹配项数据
                 timer: null // 定时器,控制请求频率
  3. 执行滚动到底部时异步加载分页数据的方法。

    复制代码
             getDatasourceList () {
               const that = this
               that.listLoading = true
               queryDatasourceList({
                 datasourceName: that.selectedVal,
                 current: that.pageNo,
                 size: that.pageSize
               }).then(response => {
                 that.datasourceCount = response.count
                 if (that.datasourceList.length <= that.datasourceCount) {
                   that.datasourceList = that.datasourceList.concat(response.data)
                 }
                 that.listLoading = false
               })
             },
             // 文本框值变化时回调
             filterOpts (val) {
               this.selectedVal = val
               if (this.selectedVal) {
                 clearTimeout(this.timer)
                 this.datasourceList = []
                 this.pageNo = 1
                 this.pageSize = 10
                 this.timer = setTimeout(() => {
                   this.getDatasourceList()
                 }, 500)
               }
             },
             // 列表滚动时加载数据
             handlePopupScroll (e) {
               const target = e.target
               // 判断滚动条滚动到底部时才加载
               if ((target.scrollTop + target.offsetHeight === target.scrollHeight) && (this.pageNo * this.pageSize < this.datasourceCount)) {
                 this.pageNo += 1
                 this.getDatasourceList()
               }
             },
             // 选中 option 调用
             clickLdapOpt (val) {
               this.selectedVal = val
               this.listQuery.datasourceId = val
             },

懒加载分页是一种优化用户体验和页面加载速度的方式。它的原理是将页面的数据分为多页,只在用户滚动页面到底部时加载下一页数据。这种方式可以减少页面加载时间,提高用户体验,但在实现时需要注意以下几点:

  1. 数据的缓存:由于只在需要时才加载数据,因此需要确保已加载的数据能够被缓存,避免多次加载同一数据。

  2. 页面滚动的监测:需要使用JS监测用户滚动页面的位置,以便在滑动到底部时触发数据加载。

  3. 分页逻辑的设计:需要按照一定的规则或算法将数据分页,确保分页的顺序和数据的连续性。

  4. 加载数据的动画:在加载数据时,可以添加加载动画或提示信息,提高用户体验。

  5. 容错处理:需要考虑到网络连接和服务器异常的情况,设计相应的容错处理机制,以便在出现错误时能够给用户友好的提示信息。

总之,懒加载分页需要综合考虑页面性能、用户体验和容错处理等方面,才能实现最佳效果。

Ant Design Vue 是一个基于 Vue.js 的 UI 组件库,由 Ant Design 设计体系提供强有力的设计资源支持。它提供了一套丰富的 UI 组件,涵盖了 Web 应用开发中常用的各种组件,比如按钮、表格、表单、弹窗、菜单等。同时,Ant Design Vue 也提供了丰富的配套工具和组件,例如 Ant Design Pro 等,可以帮助开发者更加高效地开发管理后台、企业级应用等。Ant Design Vue 具有丰富的主题支持,其样式可定制,可根据不同的品牌、颜色等需求进行个性化定制和风格展现,具有灵活度和可扩展性,是一个优秀的 Vue.js UI 组件库。

相关推荐
IT_陈寒8 分钟前
SpringBoot配置加载顺序把我坑惨了
前端·人工智能·后端
kyriewen11 分钟前
Next.js部署:从本地跑得欢,到线上飞得稳
前端·react.js·next.js
Moment15 分钟前
面试官:给 llm 传递上下文,有哪几个身份 role ❓❓❓
前端·后端·面试
跨境数据猎手25 分钟前
跨境独立站系统技术拆解(附带源码)
服务器·前端·php
豹哥学前端36 分钟前
用猜数字游戏,一口气掌握 JavaScript 核心知识点(附完整代码)
前端·javascript
忆往wu前1 小时前
从0到1一步步拆解搭建,梳理一个 Vue3 简易图书后台全开发流程
前端·javascript·vue.js
木斯佳1 小时前
前端八股文面经大全:字节抖音前端三面(2026-04-27)·面经深度解析
前端·面试·笔试·八股·面经
shao9185161 小时前
第3章(2)——使用Gradio JavaScript Client
javascript·node.js·cdn·gradio·job·events·playcode
光影少年1 小时前
大屏页面,一次多个请求,请求加密导致 点击 全局时间选择器 时出现卡顿咋解决(面板收起会延迟1~2秒)
前端·javascript·vue.js·学习·前端框架·echarts·reactjs
Mr.mjw2 小时前
vue中封装一个环形进度条组件,根据外部盒子大小自适应变化
前端·javascript·vue.js