首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用pdfMake转换JSON数据

使用pdfMake转换JSON数据
EN

Stack Overflow用户
提问于 2019-04-05 22:34:33
回答 1查看 1.8K关注 0票数 1

我有一个code snippet from bpampuch,可以将JSON数据转换成pdf格式。它以前对我有效,但当我链接我自己的本地JSON文件时,它停止工作。我不能100%确定我需要做哪些修复才能转换我自己的JSON数据-我认为这与行data.jsonData.forEach有关(见下文),但我不确定还有什么。对此有什么想法吗?

JS代码片段:

代码语言:javascript
复制
import $ from 'jquery';
import jsonData from "./test.json";
import pdfMake from 'pdfmake/build/pdfmake.min.js';

function _buildTableBody(data, cols) {
        let body = [];  
        body.push(cols);

        data.jsonData.forEach(function(row) { // reg obj doesn't have forEach
            let dataRow = [];

            cols.forEach(function(column) {
                dataRow.push(row[column].toString());
            })

            body.push(dataRow);
        });

        return body;
    }

    function _table(data, cols) {
        return {
            table: {
                headerRows: 1,
                body: _buildTableBody(data, cols)
            }
        };
    }

    function _printFunc() {
        var docDefinition = {
            content: [
                { text: 'Dynamic Parts', style: 'header' },
                _table(jsonData.d.results[0].Title, ['Title'])
            ]
        };

        pdfMake.createPdf(docDefinition).download(name + '.pdf');
        console.log(docDefinition.content)
    }

    $("#pdf-trigger").on("click", _printFunc)

JSON代码片段:

代码语言:javascript
复制
{
  "d": {
    "results": [
      {
        "FileSystemObjectType": 0,
        "Id": 1,
        "Title": "TitleHere",
        "GoalRange": "3",
        "Office": "Somewhere",
        "Role": "FPSL",
        "IsFilled": false,
        "Employee": null,
        "IsActive": true,
        "Notes": null,
        "ID": 1,
        "Attachments": false
...etc
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-05 22:45:34

您的json文件显然与演示文件的格式不同。尝试从您遇到问题的行中删除.jsonData:

代码语言:javascript
复制
data.forEach(function(row) { // reg obj doesn't have forEach

再往下看,你会看到这条线

代码语言:javascript
复制
_table(jsonData.d.results[0].Title, ['Title'])

将其保留为数组

代码语言:javascript
复制
_table(jsonData.d.results, ['Title'])
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55537760

复制
相关文章

相似问题

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