首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SheetJS -如何将HTML导出到Excel?

SheetJS -如何将HTML导出到Excel?
EN

Stack Overflow用户
提问于 2018-05-22 20:02:13
回答 2查看 16.2K关注 0票数 6

我从本教程中复制了代码:

https://sheetjs.com/demos/table.html

代码语言:javascript
复制
function doit(type, fn, dl) {
   var elt = document.getElementById('data-table');
   var wb = XLSX.utils.table_to_book(elt, {sheet:"Sheet JS"});
   return dl ?
    XLSX.write(wb, {bookType:type, bookSST:true, type: 'base64'}) :
    XLSX.writeFile(wb, fn || ('test.' + (type || 'xlsx')));
}

最后,我用角创建了这个方法:

代码语言:javascript
复制
exportTableToExcel() {
   var type = "xlsx"
   var elt = document.getElementsByClassName('table');
   var wb = XLSX.utils.table_to_book(elt, /*{sheet:"Sheet JS"}*/);
   return XLSX.writeFile(wb, undefined || ('test.' + (type || 'xlsx')));
}

在table_to_book方法的行中,我收到了这个异常:

table.getElementsByTagName不是一个函数

我也试过这个教程,这是类似的,但它是角4,而不是5。

http://vinhboy.com/blog/2017/06/13/how-to-use-sheetjs-xlsx-with-angular-4-typescript-in-the-browser/

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-05-22 20:23:34

不建议将Jquery与角混合,您可以在角中使用ViewChild来访问DOM元素

可以访问具有模板引用变量的本机DOM元素。

示例

HTML

代码语言:javascript
复制
    <div class="container">
        <table class="table" #table>
//....................

组件

代码语言:javascript
复制
import {Component,ViewChild, ElementRef} from '@angular/core';
     import * as XLSX from 'xlsx';
    export class AppComponent  {
  @ViewChild('table') table: ElementRef;

ExportToExcel()
    {
      const ws: XLSX.WorkSheet=XLSX.utils.table_to_sheet(this.table.nativeElement);
      const wb: XLSX.WorkBook = XLSX.utils.book_new();
      XLSX.utils.book_append_sheet(wb, ws, 'Sheet1');

      /* save to file */
      XLSX.writeFile(wb, 'SheetJS.xlsx');

    }
    }

演示

票数 9
EN

Stack Overflow用户

发布于 2018-05-22 20:07:37

document.getElementsByClassName('table');返回一个NodeList,而getElementById('data-table');返回一个节点。

如果只想使用table类的第一个元素,请执行以下操作:

代码语言:javascript
复制
var elt = document.getElementsByClassName('table')[0];
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50475638

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档