javascript - 使用 JQuery 将表格下载为 PNG

标签 javascript jquery html download

我想将 html 表格下载为 PNG 图像,我找到了一种使用 JQuery 将表格提取为图像的方法,但它会在新选项卡中打开并且不会自动下载我必须使用右键单击然后另存为图像能够下载它。

有什么办法让它自动下载吗?

这是用于导出为 PNG 图像的 JQuery

$('#preview-table').tableExport({type:'png',escape:'false'});

最佳答案

为了执行此操作并强制浏览器将数据下载为文件,您必须将 mime 类型从 data:image 更改为 data:application/octet-stream。您需要创建自己的 html2canvas 转换并手动处理 onrendered 事件。然后在 onrendered 事件处理函数中,存储 Canvas 数据 url。之后,使用正则表达式将 base64 数据 mime 类型从 data:image 更改为 data:application/octet-stream。然后你可以使用window.open(uri)强制浏览器下载文件,但是如果你想指定一个文件名,你需要创建一个 anchor 链接元素并设置下载属性你想要的文件名:

HTML:

<table id="preview-table">
  <tr>
    <th>Company</th>
    <th>Contact</th>
    <th>Country</th>
  </tr>
  <tr>
    <td>Alfreds Futterkiste</td>
    <td>Maria Anders</td>
    <td>Germany</td>
  </tr>
  <tr>
    <td>Centro comercial Moctezuma</td>
    <td>Francisco Chang</td>
    <td>Mexico</td>
  </tr>
  <tr>
    <td>Ernst Handel</td>
    <td>Roland Mendel</td>
    <td>Austria</td>
  </tr>
  <tr>
    <td>Island Trading</td>
    <td>Helen Bennett</td>
    <td>UK</td>
  </tr>
  <tr>
    <td>Laughing Bacchus Winecellars</td>
    <td>Yoshi Tannamuri</td>
    <td>Canada</td>
  </tr>
  <tr>
    <td>Magazzini Alimentari Riuniti</td>
    <td>Giovanni Rovelli</td>
    <td>Italy</td>
  </tr>
</table>


<button id="export">Table Export</button>

CSS:

table {
    font-family: arial, sans-serif;
    border-collapse: collapse;
    width: 100%;
}

td, th {
    border: 1px solid #dddddd;
    text-align: left;
    padding: 8px;
}

tr:nth-child(even) {
    background-color: #dddddd;
}

Javascript:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="tableExport.jquery.plugin/html2canvas.js"></script>

<script type="text/javascript">

$('#export').on('click', function() {
    html2canvas($('#preview-table'), {
        onrendered: function(canvas) {                                      

            var saveAs = function(uri, filename) {
                var link = document.createElement('a');
                if (typeof link.download === 'string') {
                    document.body.appendChild(link); // Firefox requires the link to be in the body
                    link.download = filename;
                    link.href = uri;
                    link.click();
                    document.body.removeChild(link); // remove the link when done
                } else {
                    location.replace(uri);
                }
            };

            var img = canvas.toDataURL("image/png"),
                uri = img.replace(/^data:image\/[^;]/, 'data:application/octet-stream');

            saveAs(uri, 'tableExport.png');
        }
    }); 
});

</script>

在这里您可以找到一个工作示例:http://zikro.gr/dbg/html/tableExport/

Check Rob W's answer on Browser/HTML Force download of image from src=“data:image/jpeg;base64…”Reddy's answer on Save file Javascript with file name [duplicate]

关于javascript - 使用 JQuery 将表格下载为 PNG,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38425931/

相关文章:

javascript - 查询/PHP : Result of jQuery function into PHP variable

javascript - ¿如何创建文本 slider 动画?

javascript - 如何组合两个 JSON 字符串以存储在数据库中

javascript - 如果所有子复选框都被选中,如何让父复选框被选中 - 文档准备好了吗?

javascript:将文本附加到文本区域性能

javascript - 多次更改 <select> 元素的选定值

javascript - 如何使用 jquery 删除外部标签(<tag></tag>)并将其余标签附加到其父级?

java - 使用 javascript 实现交易/报价 API(c++ 或 Java)

javascript - React Router 不会根据状态重定向

javascript - backbone.js 三向模型同步