javascript - 将 jtable 导出到 IE 上的 javascript 中的 excel

标签 javascript sql vb.net excel jquery-jtable

有很多方法可以将 html 表导出到 excel,但是 jtable 不包含像 <table> 这样的 html 标签呢?在页面中,它只是通过 ID 调用,如 <div id="table"></div>

我有一个简单的解决方案,可以在 Chrome 上运行,但不能在 IE 上运行

导出按钮:

<a id="dlink"  onclick="tableToExcel('StudentTableContainer', 'name', 'TestExcelFile.xls')">Export to excel</a>

J表:

<div id="StudentTableContainer"></div>

Javascript:

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();

    }
})()
  • 我们可以让它在 IE 上使用吗?
  • 我们怎样才能显示所有的值 table ? (因为此解决方案仅导出页面上显示的行)

我正在使用 vb.net 获取 jtable 的 sql 值

最佳答案

为了导出所有行,您可以创建另一个不带分页的 jtable,您仅在导出前加载它,并且对最终用户不可见。应该是这样的:

$('#PersonTable').jtable({
    //...
    paging: false, //Set paging disabled
    actions: {
        //...
    },
    fields: {
        //...
    }
});

获得完整的 jtable 后,您可以使用 this forum 中的解决方案将其导出.您可以在第二个 jtable 中仅指定要在 excel 中导出的列。

关于javascript - 将 jtable 导出到 IE 上的 javascript 中的 excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30450462/

相关文章:

javascript - jQuery - 使用 replaceWith 时显示加载消息

javascript - 在 Nuxt.js 中,如何将某些路由限制为仅具有有效 JWT token 的客户端?

sql - 更新和选择

mysql - 在坏表上加入 MySQL 表

vb.net -++1是什么意思

javascript - 如何使用单选按钮填充文本框

sql - 使用 sqldf 保留时间类

SQL SELECT 和 SUM 来自三个

c# - 为什么使用 Interaction.Shell 方法会出现文件未找到异常?

javascript - 将使用图像的自动完成添加到 MVC 应用程序中的搜索框