【发布时间】:2021-01-11 01:16:18
【问题描述】:
我的应用程序中有一个剑道网格,我已将导出到 excel 按钮添加到该剑道网格。
我的问题是如果选择剑道网格中的少量数据,当点击导出按钮时一切正常
但问题是如果选择超过 1000 行的大量数据,则网页会崩溃并显示“Aw, Snap”错误
我的环境:C#、Jquery、Kendo Grid
我的 js 中有这段代码
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))
}
})()
tableToExcel("table2excel");
当数据很小时它工作得很好。但如果数据量超过 1000 则浏览器会崩溃
我听说 Chrome 只能处理大约 200 万个字符长的 HREF。那么我可以使用 Blob 对象来处理这个问题吗?如果是的话,有人可以告诉我如何在我的情况下使用 blob 对象吗?
请帮助解决这个问题。
【问题讨论】:
-
给 Telerik 加张票。我没有遇到这种类型的问题。
-
嗨 vijay,我的问题是 href 长度.. 不是剑道网格
-
请分享屏幕截图。