web-dev-qa-db-fra.com

jsPDF: html2canvas non chargé lors de l'utilisation de la nouvelle méthode .html ()

Je veux utiliser jsPDF.html pour convertir la page html en pdf, et j'utilise ce code:

savePdf () {
  var pdf = new jsPDF({unit: 'mm', format: 'a4', orientation: 'portrait' })
  pdf.html(document.getElementById('printable-cv'), {
    callback: function (pdf) {
      pdf.save('cv-a4.pdf');
    }
  })
}

mais je reçois une erreur html2canvas not loaded: est-ce quelque chose que j'ai oublié? J'ai html2canvas

"html2canvas": "^ 1.0.0-alpha.12"

J'utilise vuejs avec webpack.

Dans la même page que j'utilise actuellement alternativement html2pdf avec le code suivant:

savePdf0 () {
  let opt = {
    filename: 'cv.pdf',
    enableLinks: true,
    image: { type: 'jpeg', quality: 0.98 },
    html2canvas: {
      scale: 8,
      useCORS: true,
      width: 310,
      letterRendering: true,
    },
    jsPDF: { unit: 'mm', format: 'a4', orientation: 'portrait' },
  }
  html2pdf().set(opt).from(document.getElementById('printable-cv')).save()
}

qui trouve correctement html2canvas.

Qu'est-ce que html2canvas not loaded Vraiment méchant? que puis-je faire pour le charger?

6
Alessandro Dentella

Pour tous ceux qui utilisent webpack ce que j'ai fait, c'est que j'ai ajouté html2canvas vers un ProvidePlugin. Vous pouvez lire à ce sujet ici Vous pouvez lire à ce sujet ici

// webpack configuration
plugins: [
    new webpack.ProvidePlugin({
        html2canvas: 'html2canvas'
    });
]
0
Martiuh