elementui table滚动分页加载

文章目录

概要

简化的实现示例:

小结


概要

在使用 Element UI 的 Table 组件时,如果需要实现滚动分页加载的功能,可以通过监听 Table 的滚动事件来动态加载更多数据。

简化的实现示例:

javascript 复制代码
<template>
    <el-table ref="scrollTable" :data="tableData" height="400">
        <!-- 列配置 -->
    </el-table>
</template>
<script>
export default {
    components: {},
    data() {
        return {
            tableData: [],
            page: 1,
            pageSize: 10,
            total: 100, // 假设总数据量为 100
        }
    },
    computed: {},
    mounted() {
        /**
         * @description:添加分页加载滚动事件
         * @return {*}
         */
        let table = this.$refs.scrollTable.bodyWrapper
        table.addEventListener('scroll', (e) => {
            const { scrollTop, clientHeight, scrollHeight } = e.target
            // 检查是否滚动到底部
            if (scrollHeight - scrollTop <= clientHeight) {
                this.page++
                if ((this.page - 1) * this.pageSize >= this.total) {
                    // 数据已全部加载完毕
                    return
                }
                this.getTableData()
            }
        })
    },

    created() {
        this.getTableData()
    },
    methods: {

        /**
         * @description:获取表格数据
         * @return {*}
         */
        getTableData() {
            let params = {
                size: this.pageSize,
                current: this.page
            }
            this.$http({ method: 'get', url: `/hello/william/page?`, params })
                .then((res) => {
                    this.tableData.push(...res.data.records)
                    this.total = res.data.total
                })
                .finally(() => { })
        },

    }
}
</script>

小结

在这个例子中,我们设置了表格的 height 属性,使其具有固定高度并可以滚动。监听 scroll 事件,当表格滚动到底部时,触发scroll 事件。在scroll 事件中,我们通过当前的 page 和 pageSize 计算已经加载的数据范围,并更新 tableData 以添加新数据。如果加载的数据超过了 total,则停止加载数据。

相关推荐
HUMHSX25 分钟前
Vue 项目启动全流程解析:从入口文件到全局指令注册与页面渲染
前端·javascript·vue.js
有颜有货36 分钟前
PMC生产排产的4种算法,一次讲清
java·服务器·前端
小虎牙00739 分钟前
Android kotlin图片库Coil源码详解
android·前端
随风一样自由1 小时前
【前端领域】前端开发核心应用场景与落地实践
前端·前端框架
an317421 小时前
弹窗数据流设计的两种高阶架构实践
前端·vue.js·架构
谢尔登1 小时前
【React】 状态管理方案
前端·react.js·前端框架
用户2136610035722 小时前
Vue商品详情与放大镜组件
前端·javascript
半个落月2 小时前
从Tapas小Demo理清localStorage、事件与this
前端·javascript
李明卫杭州2 小时前
Vue2 中 v-model 处理不同数据结构的技巧
前端·javascript·vue.js
李明卫杭州2 小时前
使用 computed 处理 v-model 复杂数据结构
前端·javascript·vue.js