Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/449.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript TypeError:无法读取属性';forEach&x27;PDF组件中未定义的_Javascript_Angular_Typescript_Foreach_Angular5 - Fatal编程技术网

Javascript TypeError:无法读取属性';forEach&x27;PDF组件中未定义的

Javascript TypeError:无法读取属性';forEach&x27;PDF组件中未定义的,javascript,angular,typescript,foreach,angular5,Javascript,Angular,Typescript,Foreach,Angular5,我犯了以下错误:我做错了什么 ng:///AppModule/PDFComponent.ngfactory.js:7 ERROR TypeError: Cannot read property 'forEach' of undefined at jspdf.plugin.autotable.min.js:12 at Object.e.parseInput (jspdf.plugin.autotable.min.js:12) at Object.s.API.autoTabl

我犯了以下错误:我做错了什么

ng:///AppModule/PDFComponent.ngfactory.js:7 ERROR TypeError: Cannot read property 'forEach' of undefined
    at jspdf.plugin.autotable.min.js:12
    at Object.e.parseInput (jspdf.plugin.autotable.min.js:12)
    at Object.s.API.autoTable (jspdf.plugin.autotable.min.js:12)
    at PDFComponent.push../src/app/Shared/Directives/Download/pdf-generator.component.ts.PDFComponent.downloadPDF (main.js:339)
    at Object.eval [as handleEvent] (ng:///AppModule/PDFComponent.ngfactory.js:13)
    at handleEvent (vendor.js:74287)
    at callWithDebugContext (vendor.js:75796)
    at Object.debugHandleEvent [as handleEvent] (vendor.js:75383)
    at dispatchEvent (vendor.js:70702)
    at vendor.js:71327
以下是我的pdf组件

import { Component, Input, EventEmitter, Output,Inject  } from '@angular/core';
import {BrowserModule} from '@angular/platform-browser';
import {AuthService} from '../../Services/auth.service';
import * as jsPDF from 'jspdf';
import 'jspdf-autotable';

declare var jsPDF: any; // Important
@Component({
    selector: 'pdf-download',
    templateUrl: './pdf-generator.component.html',

})
export class PDFComponent   {
    @Input() downloadData: any; 
    @Input() columns: any; 
    @Input() reportName: string; 
    constructor(private authService: AuthService) { }
    // public columns=[];
    downloadPDF(){
        debugger;

        var data = this.downloadData;

        var doc = new jsPDF('landscape');

        //..................................................Row1 start
        var imgData = '';
        doc.addImage(imgData, 'PNG', 0, 5);

        doc.setFontSize(16);
        //doc.setFontType("bold");
        doc.text(100, 15, "Report Name: "+this.reportName);

        doc.setFontSize(10);
       // jaison doc.text(230, 15, "User: "+this.authService.getLoginUserData().FullName);
        //..................................................Row1 END

         //..................................................Row2 start
        doc.setFontSize(10);
        // doc.setFontType("normal")
        doc.text(10, 25, "Date: " + new Date().toDateString() + " Time: " + new Date().toLocaleTimeString());
        //doc.text(5, 25, "1st");

        //doc.setFontSize(10);
       //doc.text(120, 25, "2nd");

        //doc.setFontSize(10);
        // doc.text(230, 25, "3rd");
         //..................................................Row2 END



        var rows = [];
        if(data.length>0)
        {
            for (var key in data) {
                debugger;
                rows.push(data[key]);
            }
        }
        else
        {
            doc.setFontSize(10);
            doc.text(230, 35, "No Data Found");
        }


        doc.autoTable(this.columns, rows, {
            styles: {
                //cellPadding: 1,
                fontSize: 10,
                rowHeight: 8,
                overflow: 'linebreak'
            },
            headerStyles: { fillColor: [65, 85, 99], valign: 'middle' },

            createdCell: function (cell, data) {
                if (cell.raw?cell.raw.toLowerCase() == "false" || cell.raw.toLowerCase() == "error":"") {
                    cell.styles.textColor = "#FF0718";
                }
                else if (cell.raw?cell.raw.toLowerCase() == "success" || cell.raw.toLowerCase() == "true":"") {
                    cell.styles.textColor = "#2ACE1E";
                }
                else if (cell.raw ? cell.raw.toLowerCase() == "fail" || cell.raw.toLowerCase() == "failed":"") {
                    cell.styles.textColor = "#FF0718";
                }
            },

            //tableWidth: 'wrap',
            theme: 'grid',
            //pageBreak: 'auto',
            margin: { left: 15, right: 5 ,top:40}
        });

        doc.save(this.reportName+".pdf");
    }

testdownload(){
    debugger;
    // for(var key in  this.downloadData[0])
        // {
        //     this.columns.push({title:key,dataKey:key})
        // }
    var columns = [
      {title: "ID", dataKey: "id"},
      {title: "Name", dataKey: "name"}, 
      {title: "Country", dataKey: "country"}, 
  ];
  var rows = [
      {"id": 1, "name": "Shaw", "country": "Tanzania"},
      {"id": 2, "name": "Nelson", "country": "Kazakhstan"},
      {"id": 3, "name": "Garcia", "country": "Madagascar"},
  ];
    var doc = new jsPDF('p', 'pt');
    doc.autoTable(columns, rows);
    doc.save("table.pdf");
  }
}

当您访问
doc.autoTable(this.columns
)时,
this.columns
是一个数组吗?您可以尝试
@Input()columns:any[]=[]
;您对
这个.columns
有任何值吗?是的column有值,我尝试了any[]=[];没有Lucka根据这一点,似乎我们需要将选项作为一个对象提供。您也可以对此进行研究。当我将虚拟值添加到此.columns中时,我可以毫无错误地下载pdf,但我不知道这些列是如何填充的。