Méthode pour générer des fichiers PDF : utilisez Node.js pour vous connecter à la base de données MySQL
P粉154798196
P粉154798196 2023-08-25 14:23:44
0
1
679
<p>J'essaie de générer un fichier PDF à l'aide de Node js, Pdfkit et pdfkit-table en utilisant des données stockées dans une base de données Mysql. J'ai besoin d'imprimer des enregistrements d'une base de données vers un tableau dans un document PDF. </p> <p>Le code suivant génère un fichier PDF vide. S'il vous plaît, aidez-moi à comprendre pourquoi il ne génère pas de fichier PDF avec des données. </p> <p>Il s'agit du fichier index.js.</p> <pre class="brush:php;toolbar:false;">var express = require('express'); var routeur = express.Router(); var PDFDocument = require('pdfkit'); var orm = require('orm'); var PDFDoc = require("pdfkit-table"); router.use(orm.express("mysql://root:@localhost:/kirula_fashion", { définir : fonction (base de données, modèles, suivant) { models.news = db.define("ledger", { identifiant : chaîne, date : Chaîne, description : Chaîne, débit : Chaîne, crédit : Chaîne, }); suivant(); } })); router.get('/', function(req, res, next) { var résultat = req.models.news.find({ }, fonction(erreur, actualité){ if(error) renvoie une erreur ; res.render('index', { news:news, title: '使用NodeJS生成PDF' }); }); }); router.get('/pdf', function(req, res, next) { var id = req.query.id; const doc = nouveau PDFDocument(); const docTable = new PDFDoc(); var result = req.models.news.find({id: id}, function(erreur, newspost){ if(error) renvoie une erreur ; autre{ si(newspost.length>0){ pour(var i=0; i<newspost.length;i++){ var date = newspost[0]['date']; var description = newspost[0]['description']; var débit = newspost[0]['débit']; var crédit = newspost[0]['crédit']; vartable = { titre : "账簿记录", sous-titre : "2020年5月", en-têtes : [ { "étiquette" : "日期", "propriété" : "date", "largeur" ​​: 100 }, { "étiquette" : "描述", "propriété" : "description", "largeur" ​​: 100 }, { "libellé": "借方", "propriété": "débit", "largeur": 100 }, { "libellé":"贷方", "propriété":"crédit", "largeur":100 } ], des données: [ { "date" :date, "description" :description, "débit" :débit, "crédit" :crédit}, { "Renderer": "function(value, i, irow){ valeur de retour + `(${(1+irow)})`; }" } ], } ; docTable.table(table, { largeur : 300, }); } } } var title = "2020年5月账簿"; var nom de fichier = encodeURIComponent (titre) + '.pdf'; res.setHeader('Content-disposition', 'attachment; filename="' + filename + '"'); res.setHeader('Type de contenu', 'application/pdf'); doc.pipe(res); doc.end(); }); }); module.exports = routeur;</pre></p>
P粉154798196
P粉154798196

répondre à tous(1)
P粉924915787

J'ai eu le même problème avec les options de données, mais pour les options de lignes, pdfkit-table a très bien fonctionné, peut-être en mappant [{..},{...}] à [[..],[.. .]] et alors utilisez l'option ligne

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal