2017-03-22 1 views
1

며칠 후, 내 문제에 대한 해결책을 찾으려고 노력합니다. @Oliver의 도움으로 AJAX가 작동합니다. 이 데이터를 가져 와서 JSON을 반환하는 PHP 코드는 다음과 같습니다.자동 테이블에 JSON 데이터 jsPDF

if (isset($_GET['nexans'])) { 

    $nexans = json_decode($_GET['nexans'], true); 

    $tab_req = array(); 


    foreach($nexans as $key => $value) { 
    $req_jsonmultipdf = $maPdoFonction - > PDF_Multi($key, $value, $_SESSION['ssetablissement_id'], '4', 'NEXANS'); 
    $tab_req[] = $req_jsonmultipdf - > fetchAll(PDO::FETCH_ASSOC); 
    } 

    $retour = array(
    "success" => true, 
    "data" => $tab_req 
); 

    header('Content-Type: application/json; charset=utf-8'); 
    echo json_encode($tab_req); 
} 

여기에 아무런 문제가 없습니다. jsPDF를 사용하여 PDF 파일을 생성해야합니다. 너무 autoTable (당신이 모르는 경우 jsPDF에 대한 플러그인)이 필요합니다. 이 PDF 파일에서는 autoTable이있는 테이블에 JSON 데이터를 삽입해야합니다.

편집 : 내 AJAX 요청에서, 그래서

$.ajax({ 
     type: "GET", 
     url: "../modules/ajax/A.php", 
     data: { 
     'A': _json 
     }, 
     dataType: 'json', 
     success: function(json) { 
      var len = json.length; 
      if (len > 0) { 

      // Default export is a4 paper, portrait, using milimeters for units 
      var pdf = new jsPDF(); 
      pdf.page = 1; 

      var trame_eiffage = ''; 
      pdf.addImage(trame_eiffage, 'PNG', 207, 3, 3, 60); 

      /* Création de tableau avec des données JSON 
                  Source : https://github.com/simonbengtsson/jsPDF-AutoTable 
                */ 
      var columns = ["Chantier", "Codet", "Désignation", "Q.", "Prix U", "Livraison à", "GPS : Lat.", "GPS : Lon."]; 

      pdf.autoTable(columns, json, { 
       styles: { 
       fillColor: [156, 154, 154], 
       }, 
       headerStyles: { 
       lineWidth: 0.35, 
       lineColor: [0, 0, 0], 
       valign: 'middle', 
       halign: 'center', 
       fontStyle: 'bold' 
       }, 
       bodyStyles: { 
       lineWidth: 0.35, 
       lineColor: [0, 0, 0] 
       }, 
       margin: { 
       horizontal: 0, 
       top: 55, 
       bottom: 0 
       }, 
       columnStyles: { 
       0: { 
        columnWidth: 18, 
        halign: 'middle', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       1: { 
        columnWidth: 17, 
        halign: 'middle', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       2: { 
        columnWidth: 'auto', 
        halign: 'left', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       3: { 
        columnWidth: 8, 
        halign: 'left', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       4: { 
        columnWidth: 13, 
        halign: 'middle', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       5: { 
        columnWidth: 'auto', 
        halign: 'left', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       6: { 
        columnWidth: 'auto', 
        halign: 'left', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       }, 
       7: { 
        columnWidth: 'auto', 
        halign: 'left', 
        fontStyle: 'bold', 
        textColor: [0, 0, 0] 
       } 
       }, 

       showHeader: 'everyPage', // 'everyPage', 'firstPage', 'never', 
       tableWidth: 183, 
       margin: { 
       top: 40, 
       right: 13, 
       bottom: 0, 
       left: 13 
       }, 
       pageBreak: 'auto', // 'auto', 'avoid' 
       overflow: 'linebreak' // visible, hidden, ellipsize or linebreak 
      }); 

      function header() { 
       /* Encodage en base64 de l'image (obligatoire) 
                   Source : https://www.base64encode.org/ 
                  */ 
       var logo_eiffage = ''; 

       pdf.setFont("helvetica"); 
       pdf.setFontType("bold"); 
       pdf.setFontSize(20); 
       pdf.text(200, 15, 'DEMANDE D\'ACHAT\r', null, null, 'right'); 
       pdf.setFontSize(8); 
       pdf.setFont("helvetica"); 
       pdf.text(189, 8, '\r\r\r\rle ' + date_du_jour + ',', null, null, 'right'); 

       pdf.addImage(logo_eiffage, 'JPEG', 8, 8, 40, 14); 
      }; 
      header(); 

      pdf.setFontSize(10); 
      pdf.setFont("helvetica"); 
      pdf.setFontType("normal"); 
      pdf.text(18, 35, 'Voici le récapitulatif de votre demande d\'achat pour le fournisseur '); 

      pdf.setFontSize(10); 
      pdf.setFont("helvetica"); 
      pdf.setFontType("bold"); 
      pdf.text(121, 35, 'X'); 

      pdf.setFontSize(10); 
      pdf.setFont("helvetica"); 
      pdf.setFontType("normal"); 
      pdf.text(136, 35, ' : '); 

      // then use this as a counter. 
      function footer() { 
       pdf.setFontSize(8); 
       pdf.setFont("helvetica"); 
       pdf.setFontType("bold"); 
       pdf.text(150, 285, 'Page ' + pdf.page); 
       pdf.page++; 
      }; 
      footer(); 

      pdf.save('A' + date_du_jour + '.pdf'); 

, 나는 배열을 얻고,이 배열, 배열 각 행의 :이 PDF file을 생성 내 JS입니다. 내 JSON을 구문 분석하고 테이블을 생성하기 위해 자동 테이블을 채우는 솔루 션을 검색해주세요. 도와 주실 분은 제발 도와주세요. 귀하의 답변에 감사드립니다.

+0

당신이 문서에 설명 된대로 autoTable에 배열을 전달 봤어 : 1은 다음과 같이 JSON 데이터를 분석, AJAX 요청을 확인하고 AJAX에있는 당신의 성공에서 2 JSON 을 반환? 만약 가지고 있다면, 시도한 코드와 잠재적 인 오류 메시지로 질문을 업데이트 할 수 있습니까? –

+0

@SimonBengtsson. 훌륭하게 작동합니다! 하지만 내 테이블에 [Object object]가 있습니다 :/ –

+0

문제가있는 PDF를 생성하는 JS로 질문을 업데이트하십시오. – Purushoth

답변

0

SOLUCE :

var rows = []; 
                           jQuery(json).each(function(i, item){ // FOR EACH ROW 
                            jQuery(item).each(function(i, item){ // EACH VALUE IN THE ROW -> INSERT DATA IN AN ARRAY WHO WILL BE USED BY JSPDF AUTOTABLE LATER 
                             rows.push([ 
                              item.chantier_ref, item.article_codet, item.description, item.quantite, item.prixU_commande+' €', item.livraison_add1 +' '+item.livraison_add2 +' '+item.livraison_add3 + item.livraison_cp +' '+item.livraison_ville, item.livraison_gps_lat+' °C', item.livraison_gps_lon+' °C' 
                             ]); 
                            }); 
                           }); 
관련 문제