【问题标题】:Is there any way to set safe content on a excel file generated from js?有没有办法在从 js 生成的 excel 文件上设置安全内容?
【发布时间】:2015-12-11 15:36:04
【问题描述】:

这是我用来生成我的 excel 文件 .xls 的函数

 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('table', 'Table Title')

这是我得到的错误

【问题讨论】:

  • 您检查错误暗示的问题了吗?扩展名 .xls 和它的内容类型匹配还是您以错误的方式设置它们?
  • 是我还是代码将创建 XLSX 文件而不是 XLS
  • @Proof:如果Officeversion 大于或等于9 &lt;!--[if gte mso 9]&gt;,则代码创建HTML 和嵌入XML 的混合体。 Excel 将接受此混合作为 *.xls 文件并解析混合以从中创建工作簿。但它会抛出那个警告。在野外有JavaScript 解决方案可以真正创建XLS 和/或XLSX。搜索关键字:javascript create excel xls xlsx.
  • 这不是错误,而是警告,它不应阻止工作表加载。如果要避免警告,请使用 CSV 输出。并且对于它的价值,你不需要所有奇怪的模板东西,一个只有 HTML 标签的文件将以完全相同的方式打开......
  • 看看here,你会找到所有答案。

标签: javascript html xml excel


【解决方案1】:

以下代码获取表格并将其转换为 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();

  }
})()
<table id="newTab">
  <th>Col 1</th>
  <th>Col 2</th>
  <th>Col 3</th>
  <tr>
    <td>1</td>
    <td>2</td>
    <td>3</td>
  </tr>
  <tr>
    <td>4</td>
    <td>5</td>
    <td>6</td>
  </tr>
  <tr>
    <td>7</td>
    <td>8</td>
    <td>9</td>
  </tr>
</table>
<a id="dlink" style="display:none;"></a>

<input type="button" onclick="tableToExcel('newTab', 'name', 'newSheet.xls')" value="Table to Excel">

打开下载的文件时可能会弹出以下错误

打开文件时出错。但无论如何,它都会通过单击“是”打开。

文件打开成功。

【讨论】:

    猜你喜欢
    • 2021-01-06
    • 2021-09-30
    • 2018-10-17
    • 2023-03-18
    • 1970-01-01
    • 2021-04-01
    • 2018-07-23
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多