gpt4 book ai didi

Angular - SheetJS - 如何将 HTML 表格导出到 Excel?

转载 作者:太空狗 更新时间:2023-10-29 18:12:37 27 4
gpt4 key购买 nike

我从这个“教程”中复制了代码:

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

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')));
}

所以我最终在 Angular 中创建了这个方法:

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 is not a function

我也试过这个教程,它很相似,但它适用于 Angular 4,而不是 5。

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

最佳答案

不推荐将 Jquery 与 Angular 混合使用 ViewChild 在 Angular 中访问 DOM 元素
您可以访问具有模板引用变量的 native DOM 元素。
示例
HTML

    <div class="container">
<table class="table" #table>
//....................

组件

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

}
}

DEMO

关于Angular - SheetJS - 如何将 HTML 表格导出到 Excel?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50475638/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com