Layui的table模块导出所有数据,无需修改前后端代码
发表于:2022-11-04 23:53:55浏览:2003次
layui table自带的导出功能仅导出单页的数据,搜索一番之后发现大部分都是通过另外发送ajax请求,让后端进行处理,或是生成excel下载链接,或是后端返回所有数据然后用table.exportFile
导出。其实可以利用render
,设置limit为总数量实现数据重新加载并导出。
var tableDataCount = 0;
table.render({
elem: '#datatable'
,url: '...数据接口'
,skin:'line'
,even:true
,method:'post'
,limit:20
,title:'数据'
,height:'full-60'
// ,size:'lg'
,cols: [[
{field:'id', width:80, title: 'ID', sort: true},
{field:'name',minWidth:'100', title: '姓名'},
]]
,page: true
, done: function(res, curr, count){
tableDataCount = count;//记录所有数据数量
}
});
//在html中设置一个导出全部的按钮,事件:
table.reload('datatable',{
page: 1,
limit:tableDataCount //加载所有数据
,where: {where}
,done:function (){
//导出所有数据
table.exportFile("datataleb",false,"xls");
//恢复数据分页显示
table.reload('datatable',{
page: 1,
limit:20
,where: {where}
,done:function (res, curr, count){
tableDataCount = count;
}
})
}
})
推荐文章
- ThinkPHP6多条件搜索查询,表达式查询 FIND_IN_SET查询
- ThinkPHP6获取数据库内所有表的表名及表信息
- aliplayer播放器,TcPlayer播放器,xgplayer播放器三款大厂的视频直播播放器对比
- ThinkPHP6使用.env配置数据库配置文件database.php的使用
- 微软推出 VS Code for the Web 无需在 PC 上进行安装 打开浏览器就可以开始工作
- PHP中如何将数组转换为JSON格式数据
- nginx跨域访问,需要如何配置?宝塔面板如何配置跨域?
- 焕然一新 新版 Vue3中文文档上线
- 烦人啊!微信总是弹出企业微信邀请信息,怎么关闭通知?
- ThinkPHP6接入阿里云短信实战:阿里云短信验证码登录