一、背景
界面显示5000条数据,el-table 直接卡死,原因就是因为el-table 采用的是DOM 内存占用过多,引起阻塞
二、解决方案
-
懒加载:即监听scroll事件或使用
IntersecionObserver
监听; -
可视区域的渲染:仅在可视区域展示数据,为保证滚动条的完整性,非可视区域使用占位元素的高度后者容器的位移来撑开。
三、整合pl-table
1、安装pl-tablb 建议采用cnpm i
npm i pl-table
cnpm i pl-table
yarn - pl-table
2、main.js 引入,整个框架采用的是element-ui 所以不引人第二个样式,使用原生的element-ui样式
import plTable from 'pl-table'
import 'pl-table/themes/index.css' // 引入样式(必须引入),vuecli3.0不需要配置,cli2.0请查看webpack是否配置了url-loader对woff,ttf文件的引用,不配置会报错哦
// import 'pl-table/themes/plTableStyle.css' // 默认表格样式很丑 引入这个样式就可以好看啦(如果你不喜欢这个样式,就不要引入,不引入就跟ele表格样式一样)
Vue.use(plTable);
3、使用
<el-table border size="mini" class="table-ui" max-height="700" :stripe="true" :data="tableData" @row-dblclick="rowDblclick" @selection-change="changeFun" @sort-change="sortChange" >
<el-table-column prop="sequenceNum" label="序号"></el-table-column>
<el-table-column prop="countyName" label="县(市、"></el-table-column>
<el-table-column prop="streetName" label="乡镇(街"></el-table-column>
<el-table-column prop="groupName" label="村(组)"></el-table-column>
</el-table>
<pl-table border size="mini" class="table-ui" max-height="700" :stripe="true" :data="tableData" @row-dblclick="rowDblclick" @selection-change="changeFun" @sort-change="sortChange" big-data-checkbox fixedColumnsRoll use-virtual>
<pl-table-column prop="sequenceNum" label="序号"></pl-table-column>
<pl-table-column prop="countyName" label="县(市、"></pl-table-column>
<pl-table-column prop="streetName" label="乡镇(街"></pl-table-column>
<pl-table-column prop="groupName" label="村(组)"></pl-table-column>
</pl-table>