js实现把网页table导成Excel(bootstrap、JqGrid、Json)

 方案一:支持IE

 //导出excel
function exportExcel(DivID,strTitle){
    if(DivID==null)
    {
    return false;
    }
    var jXls, myWorkbook, myWorksheet;    
    try {
        jXls = new ActiveXObject('Excel.Application');
    }
    catch (e) {
        alert("无法启动Excel!\n\n如果您确信您的电脑中已经安装了Excel,"+"那么请调整IE的安全级别。\n\n具体操作:\n\n"+"工具 → Internet选项 → 安全 → 自定义级别 → 对

没有标记为安全的ActiveX进行初始化和脚本运行 → 启用");
        return false;
    }    
    jXls.DisplayAlerts = false;    
    myWorkbook = jXls.Workbooks.Add();    
    var curTb = document.getElementById(DivID);     
    myWorksheet = myWorkbook.ActiveSheet;    
    myWorksheet.name=strTitle;    
    var sel = document.body.createTextRange(); 
    sel.moveToElementText(curTb);    
    sel.select();    
    window.clipboardData.setData('text','');    
    sel.execCommand("Copy");    
    myWorksheet.Paste();     
    jXls.Visible = true;    
     try{
        var fname = jXls.Application.GetSaveAsFilename("OA数据"+strTitle+".xls", "Excel Spreadsheets (*.xls), *.xls");
        }catch(e){
        print("Nested catch caught " + e);
    }
    finally{
        if(fname!=false)
        {
             myWorkbook .SaveAs(fname);
            alert("数据成功保存在:"+fname);       
        }
     }
     //   myWorkbook .Close(savechanges=false);
     // jXls.Quit();
    window.clipboardData.setData('text','');
    jXls = null;
    myWorkbook = null;
    myWorksheet = null;
}

 

<table class="oa-el-grid-list" id="tb" style="width:99%" cellspacing="0" cellpadding="0"
            border="0">
            <thead>
                <%=tab_html%>
            </thead>
            <%=TableHtml %>
        </table>


  <input id="btnSavExcel" onclick="exportExcel('tb','……表')" type="button" value="导出"  />

 方案2

<input type="button" onclick="tableToExcel('tablename', 'name')" value="Export to Excel">
var tableToExcel = (function() {
var uri = 'data:application/vnd.ms-excel;base64,'
, template = '<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"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>'
, base64 = function(s) { return window.btoa(unescape(encodeURIComponent(s))) }
, format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) }
return function(table, name) {
if (!table.nodeType) table = document.getElementById(table)
var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML}
window.location.href = uri + base64(format(template, ctx))
}
})()

 

方案3

<a id="dlink"  style="display:none;"></a>

<input type="button" onclick="tableToExcel('tablename', 'name', 'myfile.xls')" value="Export to Excel">
var tableToExcel = (function () {
        var uri = 'data:application/vnd.ms-excel;base64,'
        , template = '<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"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>'
        , base64 = function (s) { return window.btoa(unescape(encodeURIComponent(s))) }
        , format = function (s, c) { return s.replace(/{(\w+)}/g, function (m, p) { return c[p]; }) }
        return function (table, name, filename) {
            if (!table.nodeType) table = document.getElementById(table)
            var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML }

            document.getElementById("dlink").href = uri + base64(format(template, ctx));
            document.getElementById("dlink").download = filename;
            document.getElementById("dlink").click();

        }
    })()

 支持:Chrome、Firefox、Opera、Safari

 

根据Json导出Excel

; !function () {

    layui.use(['layer', 'element'], function () {

    var tableTitle = [{ "value": "行政区", "type": "ROW_HEADER_HEADER", "datatype": "string" }, { "value": "留守儿童(人)", "type": "ROW_HEADER_HEADER", "datatype": "string" }, { "value": "困境儿童(人)", "type": "ROW_HEADER_HEADER", "datatype": "string" },{"value": "合计(人)", "type": "ROW_HEADER_HEADER", "datatype": "string" }]
    $(".querynav a:eq(2)").click(function (param) {  
        var tableData=[];
        layer.confirm("确认导出当前页数据?",function(params) {
                $.each($(".tableBody tr"),function (i,lay) {
                    var data=[];
                     layer.closeAll();
                    for(i=0;i<$(this).children().length;i++){
                        var a="{value:'"+$(this).children().eq(i).text()+"',type:'ROW_HEADER'}";
                        data.push( eval("(" + a + ")"));
                    }
                    tableData.push(data);
                    console.log(data.toString());
                });
                console.log(tableData.toString());
                var cityName="";
                if ($("#Town").val() != "") {
                    civilregionalismcode += 'civilregionalismcode=' + $("#Town").val();
                }
                else if ($("#Country").val() != "") {
                    civilregionalismcode += 'civilregionalismcode=' + $("#Country").val();
                }
                else if ($("#city").val() != "") {
                    civilregionalismcode += 'civilregionalismcode=' + $("#city").val();
                }
                else if ($("#province").val() != "") {
                    civilregionalismcode += 'civilregionalismcode=' + $("#province").val();
                }
                // return;
                JSONToExcelConvertor(tableData, "测试数据", tableTitle)
        })

    });

     function JSONToExcelConvertor(JSONData, FileName, ShowLabel) {  
            //先转化json  
            var arrData = typeof JSONData != 'object' ? JSON.parse(JSONData) : JSONData;  
              
            var excel = '<table>';      
              
            //设置表头  
            var row = "<tr>";  
            for (var i = 0, l = ShowLabel.length; i < l; i++) {  
                row += "<td>" + ShowLabel[i].value + '</td>';  
            }  
              
              
            //换行  
            excel += row + "</tr>";  
            console.log(arrData);
        //   return;
              
            //设置数据  
            for (var i = 0; i < arrData.length; i++) {  
                var row = "<tr>";  
                  
                for (var index in arrData[i]) {  
                    var value = arrData[i][index].value === "." ? "" : arrData[i][index].value;  
                    row += '<td>' + value + '</td>';  
                }  
                  
                excel += row + "</tr>";  
            }  
  
            excel += "</table>";  
  
            var excelFile = "<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'>";  
            excelFile += '<meta http-equiv="content-type" content="application/vnd.ms-excel; charset=UTF-8">';  
            excelFile += '<meta http-equiv="content-type" content="application/vnd.ms-excel';  
            excelFile += '; charset=UTF-8">';  
            excelFile += "<head>";  
            excelFile += "<!--[if gte mso 9]>";  
            excelFile += "<xml>";  
            excelFile += "<x:ExcelWorkbook>";  
            excelFile += "<x:ExcelWorksheets>";  
            excelFile += "<x:ExcelWorksheet>";  
            excelFile += "<x:Name>";  
            excelFile += "{worksheet}";  
            excelFile += "</x:Name>";  
            excelFile += "<x:WorksheetOptions>";  
            excelFile += "<x:DisplayGridlines/>";  
            excelFile += "</x:WorksheetOptions>";  
            excelFile += "</x:ExcelWorksheet>";  
            excelFile += "</x:ExcelWorksheets>";  
            excelFile += "</x:ExcelWorkbook>";  
            excelFile += "</xml>";  
            excelFile += "<![endif]-->";  
            excelFile += "</head>";  
            excelFile += "<body>";  
            excelFile += excel;  
            excelFile += "</body>";  
            excelFile += "</html>";  
  
              
            var uri = 'data:application/vnd.ms-excel;charset=utf-8,' + encodeURIComponent(excelFile);  
              
            var link = document.createElement("a");      
            link.href = uri;  
              
            link.style = "visibility:hidden";  
            link.download = FileName + ".xls";  
              
            document.body.appendChild(link);  
            link.click();  
            document.body.removeChild(link);  
        }  

    })

} ()

 

 方案4:

/*将JqGrid导出Excel(中文)*/
<script src="/UILib/tableExport.jquery.plugin-master/libs/FileSaver/FileSaver.min.js"></script>
<script src="/UILib/tableExport.jquery.plugin-master/tableExport.min.js"></script>
<script type="text/javascript">
//导出数据
function ExportData() {
    var tbId = "datagrid";

    //var $tb = $("#" + tbId).clone();
    var $tbst = $("table[aria-labelledby='gbox_" + tbId + "']");
    $tbst.find("td:hidden").remove();
    var $tbs = $tbst.clone();
    $tbs.find("span").remove();

    var $tb;
    if ($tbs.length > 1) {
        var $tbody = $($tbs[1]).children("tbody");
        $tbody.children("tr[class='jqgfirstrow']").remove();
        $($tbs[0]).append($tbody);
        $tb = $($tbs[0]);

        //$tb.children("tbody tr[class='jqgfirstrow']").remove();
        $tb.children("thead").children("tr[class='jqg-first-row-header']");

        $tb.attr("id", "tb_Temp_Export");
        //$tb.hide();//隐藏之后出现导出为空
        var $div = $("<div style='width:0px;height:0px;overflow:hidden;z-index:-1;'></div>").append($tb);
        $(document.body).append($div);

        var tbRepName = "数据报表";
        var exName = tbRepName;//+ "(" + $('#txtSTime').val() + ")";

        $tb.tableExport({
            fileName: exName, type: 'excel', worksheetName: [tbRepName]
           , mso: {
               styles: ['background-color', 'background', 'color', 'font-family', 'font-size', 'font-weight', 'text-align', 'height', 'width']
           }
        });

        setTimeout(function () {
            $div.remove();
        }, 2000);
    } else {
        alert("操作失败,请刷新后重试!");
    }

}

</script>

 注:加入styles样式时,可能会导出报错

 

其它案例:

HTML用JS导出Excel的五种方法

细说JavaScript 导出 上万条Excel数据

 

git_demo

https://github.com/kayalshri/tableExport.jquery.plugin/blob/master/tableExport.js

https://github.com/hhurz/tableExport.jquery.plugin

https://github.com/wenzhixin/bootstrap-table/blob/master/src/extensions/export/bootstrap-table-export.js

转载于:https://www.cnblogs.com/elves/p/3593177.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值