Chart.jsのグラフを含んだ複数ページのレポートを、html2canvasを使ってキャプチャして、PDF生成するシステムを作っています。
フレームワークはLaravel。Ajaxでの送信を試みています。
html2canvasでキャプチャするページ数が多いため、画像生成に時間がかかるため、画像生成を待ってからAjaxで送れるように、Promiseを使って送ろうとしています。
以下がコードです。
java
1 function shotPages(form) { 2 // PDF化するdivを取得 3 var pages = document.getElementsByClassName("printing-page"); 4 // 印刷するページの数だけループ 5 for(i=0;i<pages.length;i++){ 6 html2canvas(pages[i],{ 7 scale: 2 // 画質向上 8 }).then(function(canvas){ 9 var imgData = canvas.toDataURL(); 10 form.append('page[]', imgData); 11 }) 12 }; 13 return new Promise(resolve => { 14 resolve(form) 15 }) 16 } 17 18function sendPages(form) { 19 $.ajax({ 20 headers: { 21 'X-CSRF-TOKEN': $('meta[name="token"]').attr('content') 22 }, 23 type:'POST', 24 url:'./generate_pdf', 25 data: form, 26 enctype: 'multipart/form-data', 27 processData : false, 28 contentType : false, 29 success: function () { 30 alert('成功!'); 31 }, 32 error: function () { 33 alert('失敗'); 34 } 35 }); 36 return new Promise(resolve => { 37 resolve('完了!') 38 }) 39} 40 41// ボタンクリックで動作 42$('#genarate_pdf').on('click',function(){ 43 // 画像を送信するためのフォームデータを作成 44 var form = new FormData(); 45 shotPages(form) 46 .then(form => { 47 return sendPages(form) 48 }) 49 .then(msg => { 50 console.log(msg) 51 }) 52});
この中で、どうしても、forループの後の
java
1.then(function(canvas){ 2 var imgData = canvas.toDataURL(); 3 form.append('page[]', imgData); 4 })
の箇所だけが、Promiseを指定しているにもかかわらず、すべてが終了してから動作してしまいます。
(Ajaxの送信時点では、formのpageがnullのためエラーが起きる)
ここの箇所だけ独立したPromise関数としたいとも考えたのですが、このthen以降はhtml2canvasライブラリの標準の記述方式のようで分解することができないでいます。
https://html2canvas.hertzen.com/
こちら、上記のthen以降を待ってから送信させるようにするための記述方法があれば、ご指南を頂けますと大変助かります。
お忙しい中、大変恐れ入りますが、よろしくお願い致します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/12/15 10:54
2020/12/17 01:19