vue3模拟生成并渲染10万条数据,并实现本地数据el-table表格分页

效果图:

一点都不卡

话不多说,直接上码

javascript 复制代码
<template>
  <div class="container">
    <h3 class="table-title">el表格 + 分页</h3>
    <el-table :data="tableList.slice((currentPage-1)*pageSize, currentPage*pageSize)"
     border height="350"
      style="width: 70%; margin-bottom: 5px;"
    >
        <el-table-column prop="id" label="ID" width="100">
        </el-table-column>
        <el-table-column prop="name" label="Name" width="200">
        </el-table-column>
        <el-table-column prop="age" label="Age" width="100">
        </el-table-column>
        <el-table-column prop="address" label="Address" width="300">
        </el-table-column>
    </el-table>
    <el-pagination
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
        :page-sizes="[100, 200, 300, 400, 500]"
        layout="prev, pager, next, sizes, total"
        :current-page="currentPage"
        :page-size="pageSize"
        :total="total"
    />
  </div>
</template>
javascript 复制代码
<script setup>
import { ref, reactive, onMounted } from 'vue'

const tableList = ref([])
const currentPage = ref(1)  // 当前第几页
const pageSize = ref(100)   // 每页显示几条数据
const total = ref(0)


const getDatas = () => {
    // 获取表格数据
    for (let i = 0; i < 100000; i++) {
        tableList.value.push({
            id: i + 1,
            name: `name-${i + 1}`,
            age: Math.floor(Math.random() * 100) + 1,
            address: `address-${i + 1}`
        })
        total.value = tableList.value.length
    }
}
onMounted(() =>{
    getDatas()
    console.log('tableList', tableList.value);
    console.log('total.value', total.value);
    
})
// 每页显示几条数据
const handleSizeChange = (val) => {
    pageSize.value = val
    console.log('pageSize.value-每页显示数据条数:', pageSize.value)
}
// 当前第几页 - 切换上/下一页
const handleCurrentChange = (val) => {
    currentPage.value = val
    console.log('currentPage.value-当前页码:',currentPage.value); 
}

</script>
javascript 复制代码
<style scoped>
.container {
    padding: 20px;
}
.table-title {
    margin-bottom: 20px;
}
</style>
相关推荐
『 时光荏苒 』15 分钟前
网页变成PDF下载到本地
前端·javascript·pdf·网页下载成
亿元程序员22 分钟前
逃离鸭科夫5人2周1个亿,我们可以做一个鸡科夫吗?
前端
十一.36641 分钟前
37-38 for循环
前端·javascript·html
波诺波41 分钟前
环境管理器
linux·前端·python
San30.1 小时前
深入理解浏览器渲染流程:从HTML/CSS到像素的奇妙旅程
前端·css·html
IT_陈寒1 小时前
5个Python 3.12新特性让你的代码效率提升50%,第3个太实用了!
前端·人工智能·后端
周杰伦_Jay1 小时前
【Python Web开源框架】Django/Flask/FastAPI/Tornado/Pyramid
前端·python·开源
艾小码1 小时前
为什么你的JavaScript代码总是出bug?这5个隐藏陷阱太坑了!
前端·javascript
辻戋3 小时前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保3 小时前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架