账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    js通过拼接table导出Excel,但数据行数有5万多行,一点击下载就出现网络错误
    21
    0

    js通过拼接table导出Excel,但数据行数有5万多行,一点击下载就出现网络错误,数据量少时正常下载
    代码如下:

    <script>

    var idTmr;
    function  getExplorer() {
        var explorer = window.navigator.userAgent ;
        //ie
        if (explorer.indexOf("MSIE") >= 0) {
            return 'ie';
        }
        //firefox
        else if (explorer.indexOf("Firefox") >= 0) {
            return 'Firefox';
        }
        //Chrome
        else if(explorer.indexOf("Chrome") >= 0){
            return 'Chrome';
        }
        //Opera
        else if(explorer.indexOf("Opera") >= 0){
            return 'Opera';
        }
        //Safari
        else if(explorer.indexOf("Safari") >= 0){
            return 'Safari';
        }
    }
    function toExcel(tableid) {
        if(getExplorer()=='ie')
        {
            var curTbl = document.getElementById(tableid);
            var oXL = new ActiveXObject("Excel.Application");
            var oWB = oXL.Workbooks.Add();
            var xlsheet = oWB.Worksheets(1);
            var sel = document.body.createTextRange();
            sel.moveToElementText(curTbl);
            sel.select();
            sel.execCommand("Copy");
            xlsheet.Paste();
            oXL.Visible = true;
    
            try {
                var fname = oXL.Application.GetSaveAsFilename("Excel.xls", "Excel Spreadsheets (*.xls), *.xls");
            } catch (e) {
                print("Nested catch caught " + e);
            } finally {
                oWB.SaveAs(fname);
                oWB.Close(savechanges = false);
                oXL.Quit();
                oXL = null;
                idTmr = window.setInterval("Cleanup();", 1);
            }
    
        }
        else
        {
            tableToExcel(tableid,'name', '项目分期报表.xls')
        }
    }
    function Cleanup() {
        window.clearInterval(idTmr);
        CollectGarbage();
    }
    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]-->' +
            '<style type="text/css">\n' +
            '        #table thead{width:100%;z-index:5;}\n' +
            '        #table td{overflow: hidden;text-overflow: ellipsis;white-space: nowrap;table-layout: fixed;padding-right: 0;}\n' +
            '        #table .project_title{background-color: #88e1ff;font-weight: bold;}\n' +
            '        #table .batch_title {font-weight: bold}\n' +
            '        #table .not_end{color: red;}\n' +
            '        #table tbody tr>td{text-align: left;padding-left: 5px;}'+
            '        .not_charge{color: blue}\n' +
            '        .charge{color: green}\n' +
            '        .pay_month{color: purple}\n' +
            '    </style>'+
            '</head><body><table id="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();
    
        }
    })()
    </script>
    

    请问各位大神我该怎么写才能让这个excel可以下载下来。

    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 孤单成性 普通会员 1楼

      这个问题可能是由于网络问题或者浏览器兼容性问题导致的。以下是一些可能的解决方法:

      1. 优化代码:确保你的JavaScript代码没有语法错误,并且使用了适当的数据类型和函数。如果可能的话,尝试减少数据行数,或者使用分页下载。

      2. 确保网络连接:检查你的网络连接是否稳定。如果你在下载数据时遇到网络错误,尝试重启网络,或者刷新页面。

      3. 浏览器兼容性:确保你的浏览器兼容性,尤其是在使用IE时。你可以使用一些工具检查你的浏览器是否支持某些功能,或者使用一些库来处理跨浏览器兼容性问题。

      4. 使用流式加载:如果你的数据行数非常大,你可以考虑使用流式加载来分批下载数据。这样可以减少网络请求的次数,从而提高下载速度。

      5. 使用异步加载:如果你的数据行数非常大,你可以考虑使用异步加载来分批下载数据。这样可以避免一次性加载所有的数据,从而提高下载速度。

      6. 使用错误处理:如果你的数据行数非常大,你可能需要使用一些错误处理来处理可能出现的问题。例如,你可以检查下载失败的原因,并尝试解决这个问题。

    更多回答
    扫一扫访问手机版