优化导出数据

This commit is contained in:
hdm 2022-12-29 17:52:11 +08:00
parent 8dd49b3300
commit fe42ceac45
10 changed files with 104 additions and 1 deletions

View File

@ -21,6 +21,7 @@
layui.pageTable = table.render({
elem: '#test'
,toolbar: '#toolbarDemo'
,defaultToolbar: false
,title:'车辆类型列表'
,url: "/adm/car/car_cate"
,page: false

View File

@ -21,6 +21,7 @@
layui.pageTable = table.render({
elem: '#test'
,toolbar: '#toolbarDemo'
,defaultToolbar: false
,title:'会议室列表'
,url: "/adm/meeting/meeting_cate"
,page: false

View File

@ -21,6 +21,7 @@
layui.pageTable = table.render({
elem: '#test'
,toolbar: '#toolbarDemo'
,defaultToolbar: false
,title:'印章类型列表'
,url: "/adm/seal/seal_cate"
,page: false

View File

@ -29,6 +29,7 @@
elem: '#test',
title: '公告列表',
toolbar: '#toolbarDemo',
defaultToolbar: false,
page: true, //开启分页
limit: 20,
url: "/note/index/index", //数据接口

View File

@ -28,6 +28,7 @@
layui.pageTable = table.render({
elem: '#test'
, toolbar: '#toolbarDemo'
,defaultToolbar: false
, url: "/user/personal/change"
, page: true //开启分页
, limit: 20

View File

@ -28,6 +28,7 @@
layui.pageTable = table.render({
elem: '#test'
, toolbar: '#toolbarDemo'
,defaultToolbar: false
, url: "/user/personal/leave"
, page: true //开启分页
, limit: 20

View File

@ -30,6 +30,7 @@
elem: '#test',
title: '岗位列表',
toolbar: '#toolbarDemo',
defaultToolbar: false,
url: "/user/position/index", //数据接口
page: false, //开启分页
cols: [

View File

@ -15,7 +15,7 @@ if (empty(file_exists(__DIR__ . '/../vendor/autoload.php'))) {
require __DIR__ . '/../vendor/autoload.php';
// 定义当前版本号
define('CMS_VERSION','4.11.24');
define('CMS_VERSION','4.12.30');
// 定义Layui版本号
define('LAYUI_VERSION','2.7.6');

View File

@ -0,0 +1,95 @@
layui.define([], function (exports) {
var MOD_NAME = 'table2excel';
var modFile = layui.cache.modules['table2excel'];
var modPath = modFile.substr(0, modFile.lastIndexOf('.'));
var plugin_filename = 'table2excel.js'
var settings = {
title: '数据表格',
url: '',
where:function(){
return {};
}
};
function tableTOexcel(opts){
let msg;
let where = opts.where();
if(!where['limit'] ){
where['limit'] = 999999;
}
$.ajax({
url:opts.url,
data:where,
beforeSend:function(){
msg = layer.msg('数据导出中...',{
time: 20000
});
$('.table-excel-out').remove();
},
success:function(res){
if(res.code==0){
var item=res.data,th=['<tr>'],headArray = opts.cols;
if(item.length==0){
layer.msg('查询无数据,无法导出');
return false;
}
for(var a=0;a<headArray.length;a++){
th.push('<th>'+headArray[a].title+'</th>');
}
th.push('</tr>');
for(var m=0;m<item.length;m++){
th.push('<tr>');
for(var n=0;n<headArray.length;n++){
let resetData = headArray[n]['reset'];
if(resetData && typeof resetData === "function"){
th.push('<td>'+resetData(item[m])+'</td>');
}
else{
th.push('<td>'+item[m][headArray[n]['field']]+'</td>');
}
}
th.push('</tr>');
}
var tableId = new Date().getTime();
$('body').append('<div class="table-excel-out" style="display:none"><table id="tableOut'+tableId+'">'+th.join('')+'</table></div>');
$("#tableOut"+tableId).table2excel({
name: opts.title,
filename: opts.title + tableId + ".xls",
exclude: ".noExl",
exclude_img: false,
exclude_links: false,
exclude_inputs: false
});
}
},
complete: function () {
layer.close(msg);
},
})
}
var table2excel = {
render: function (btnId, options) {
loadScript();
var opts = $.extend({}, settings, options);
$('body').on('click','#'+btnId,function(){
tableTOexcel(opts);
})
}
}
function loadScript() {
if (typeof $.fn['table2excel'] == 'undefined') {
$.ajax({
url: modPath + '/' + plugin_filename,
dataType: 'script',
cache: true,
async: false,
});
}
}
exports(MOD_NAME, table2excel);
});

View File

@ -0,0 +1 @@
(function($,window,document,undefined){var pluginName="table2excel",defaults={exclude:".noExl",name:"Table2Excel",filename:"table2excel",fileext:".xls",exclude_img:true,exclude_links:true,exclude_inputs:true,preserveColors:false};function Plugin(element,options){this.element=element;this.settings=$.extend({},defaults,options);this._defaults=defaults;this._name=pluginName;this.init()}Plugin.prototype={init:function(){var e=this;var utf8Heading='<meta http-equiv="content-type" content="application/vnd.ms-excel; charset=UTF-8">';e.template={head:'<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40">'+utf8Heading+"<head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets>",sheet:{head:"<x:ExcelWorksheet><x:Name>",tail:"</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet>"},mid:"</x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body>",table:{head:"<table>",tail:"</table>"},foot:"</body></html>"};e.tableRows=[];var additionalStyles="";var compStyle=null;$(e.element).each(function(i,o){var tempRows="";$(o).find("tr").not(e.settings.exclude).each(function(i,p){additionalStyles="";if(e.settings.preserveColors){compStyle=getComputedStyle(p);additionalStyles+=(compStyle&&compStyle.backgroundColor?"background-color: "+compStyle.backgroundColor+";":"");additionalStyles+=(compStyle&&compStyle.color?"color: "+compStyle.color+";":"")}tempRows+="<tr style='"+additionalStyles+"'>";$(p).find("td,th").not(e.settings.exclude).each(function(i,q){additionalStyles="";if(e.settings.preserveColors){compStyle=getComputedStyle(q);additionalStyles+=(compStyle&&compStyle.backgroundColor?"background-color: "+compStyle.backgroundColor+";":"");additionalStyles+=(compStyle&&compStyle.color?"color: "+compStyle.color+";":"")}var rc={rows:$(this).attr("rowspan"),cols:$(this).attr("colspan"),flag:$(q).find(e.settings.exclude)};if(rc.flag.length>0){tempRows+="<td> </td>"}else{tempRows+="<td";if(rc.rows>0){tempRows+=" rowspan='"+rc.rows+"' "}if(rc.cols>0){tempRows+=" colspan='"+rc.cols+"' "}if(additionalStyles){tempRows+=" style='"+additionalStyles+"'"}tempRows+=">"+$(q).html()+"</td>"}});tempRows+="</tr>"});if(e.settings.exclude_img){tempRows=exclude_img(tempRows)}if(e.settings.exclude_links){tempRows=exclude_links(tempRows)}if(e.settings.exclude_inputs){tempRows=exclude_inputs(tempRows)}e.tableRows.push(tempRows)});e.tableToExcel(e.tableRows,e.settings.name,e.settings.sheetName)},tableToExcel:function(table,name,sheetName){var e=this,fullTemplate="",i,link,a;e.format=function(s,c){return s.replace(/{(\w+)}/g,function(m,p){return c[p]})};sheetName=typeof sheetName==="undefined"?"Sheet":sheetName;e.ctx={worksheet:name||"Worksheet",table:table,sheetName:sheetName};fullTemplate=e.template.head;if($.isArray(table)){Object.keys(table).forEach(function(i){fullTemplate+=e.template.sheet.head+sheetName+i+e.template.sheet.tail})}fullTemplate+=e.template.mid;if($.isArray(table)){Object.keys(table).forEach(function(i){fullTemplate+=e.template.table.head+"{table"+i+"}"+e.template.table.tail})}fullTemplate+=e.template.foot;for(i in table){e.ctx["table"+i]=table[i]}delete e.ctx.table;var isIE=navigator.appVersion.indexOf("MSIE 10")!==-1||(navigator.userAgent.indexOf("Trident")!==-1&&navigator.userAgent.indexOf("rv:11")!==-1);if(isIE){if(typeof Blob!=="undefined"){fullTemplate=e.format(fullTemplate,e.ctx);fullTemplate=[fullTemplate];var blob1=new Blob(fullTemplate,{type:"text/html"});window.navigator.msSaveBlob(blob1,getFileName(e.settings))}else{txtArea1.document.open("text/html","replace");txtArea1.document.write(e.format(fullTemplate,e.ctx));txtArea1.document.close();txtArea1.focus();sa=txtArea1.document.execCommand("SaveAs",true,getFileName(e.settings))}}else{var blob=new Blob([e.format(fullTemplate,e.ctx)],{type:"application/vnd.ms-excel"});window.URL=window.URL||window.webkitURL;link=window.URL.createObjectURL(blob);a=document.createElement("a");a.download=getFileName(e.settings);a.href=link;document.body.appendChild(a);a.click();document.body.removeChild(a)}return true}};function getFileName(settings){return(settings.filename?settings.filename:"table2excel")}function exclude_img(string){var _patt=/(\s+alt\s*=\s*"([^"]*)"|\s+alt\s*=\s*'([^']*)')/i;return string.replace(/<img[^>]*>/gi,function myFunction(x){var res=_patt.exec(x);if(res!==null&&res.length>=2){return res[2]}else{return""}})}function exclude_links(string){return string.replace(/<a[^>]*>|<\/a>/gi,"")}function exclude_inputs(string){var _patt=/(\s+value\s*=\s*"([^"]*)"|\s+value\s*=\s*'([^']*)')/i;return string.replace(/<input[^>]*>|<\/input>/gi,function myFunction(x){var res=_patt.exec(x);if(res!==null&&res.length>=2){return res[2]}else{return""}})}$.fn[pluginName]=function(options){var e=this;e.each(function(){if(!$.data(e,"plugin_"+pluginName)){$.data(e,"plugin_"+pluginName,new Plugin(this,options))}});return e}})(jQuery,window,document);