2017-12-19 15 views
0

内で次のアプローチをJavaScriptでExcelにインライン画像を書き込むためにどのように動作します:キャッチされない例外TypeError:jszipはコンストラクタではありません。AngularJs

https://jsfiddle.net/coolcatDev/Lhzdo2qp/

しかし、一度、私は次のエラーを取得するアンギュラ環境内に置かれました:

http://jsfiddle.net/coolcatDev/ADukg/17027/

enter image description here

私は、次のライブラリを使用しています:

https://code.angularjs.org/angular-1.0.1.js

https://rawgit.com/xSirrioNx/js-xlsx/master/xlsx.js

https://rawgit.com/SheetJS/js-xlsx/master/shim.js

https://rawgit.com/SheetJS/js-xlsx/master/dist/cpexcel.js

https://rawgit.com/xSirrioNx/js-xlsx/master/jszip.js

https://rawgit.com/eligrey/FileSaver.js/master/FileSaver.js

失敗コード:コントローラー:

var myApp = angular.module('myApp',[]); 

    myApp.controller('MyCtrl', ['$scope', 
    function ($scope) { 
     $("#exportxlsx").click(exportToExcel); 
     function Workbook() { 
      if (!(this instanceof Workbook)) return new Workbook(); 
      this.SheetNames = []; 
      this.Sheets = {}; 
     } 
     function imgToDataUrl(img){ 
      var canvas = document.createElement('canvas'); 
      canvas.width = img.naturalWidth; // or 'width' if you want a special/scaled size 
      canvas.height = img.naturalHeight; // or 'height' if you want a special/scaled size 

      canvas.getContext('2d').drawImage(img, 0, 0); 
      return canvas.toDataURL('image/png').replace(/^data:image\/(png|jpg);base64,/, ''); 
     } 

     function exportToExcel() { 
      var wbout = XLSX.write(wb, {bookType:"xlsx", bookSST:true, type: 'binary'}); 
      var fname = 'test.xlsx'; 
      try { 
      saveAs(new Blob([s2ab(wbout)],{type:"application/octet-stream"}), fname); 
      } catch(e) { if(typeof console != 'undefined') console.log(e, wbout); } 
      return wbout; 
     } 

     function s2ab(s) { 
      if(typeof ArrayBuffer !== 'undefined') { 
      var buf = new ArrayBuffer(s.length); 

      var view = new Uint8Array(buf); 
      for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF; 

      return buf; 
      } else { 
      var buf = new Array(s.length); 
      for (var i=0; i!=s.length; ++i) buf[i] = s.charCodeAt(i) & 0xFF; 
      return buf; 
      } 
     } 
     var images = []; 
     var wb = new Workbook(); 
     var ws_name = "SheetJS"; 
     wb.SheetNames.push(ws_name); 
     var ws = {}; 
     var rows = $("#table tr"); 
     var rowsCount = rows.length; 
     var colsCount = $(rows[0]).find("td").length; 
     var range = {s: {c: 0, r: 0}, e: {c: colsCount - 1, r: rowsCount - 1}}; 
     ws['!ref'] = XLSX.utils.encode_range(range); 

     $.each(rows, function(rowIndex, row){ 
      var cols = $(row).find("td"); 
      $.each(cols, function(colIndex, col){ 
      var cell_ref = XLSX.utils.encode_cell({c: colIndex, r: rowIndex}); 
      var excelCell = { 
       v: $(col).text(), 
       t: "s", 
       s: { 
       fill: { 
        patternType: "none", 
        fgColor: {rgb: "FF000000"}, 
        bgColor: {rgb: "FFFFFFFF"} 
       }, 
       font: { 
        name: 'Times New Roman', 
        sz: 16, 
        color: {rgb: "#FF000000"}, 
        bold: false, 
        italic: false, 
        underline: false 
       }, 
       border: { 
        top: {style: "thin", color: {auto: 1}}, 
        right: {style: "thin", color: {auto: 1}}, 
        bottom: {style: "thin", color: {auto: 1}}, 
        left: {style: "thin", color: {auto: 1}} 
       } 
       } 
      }; 

      if(rowIndex == 0){ 
       excelCell.s.font.bold = true; 
       excelCell.s.fill.patternType = "solid"; 
       excelCell.s.fill.fgColor = { 
       rgb: "FFFF0000" 
       }; 
       excelCell.s.fill.bgColor = { 
       rgb: "FFFF0000" 
       }; 
      } 

      if($(col).find("img").length > 0){ 
       images.push({ 
       c: colIndex, 
       r: rowIndex, 
       element: $(col).find("img") 
       }) 
      } 
      ws[cell_ref] = excelCell; 
      }) 
     }); 
     ws["!images"] = []; 
     $.each(images, function(index, image){ 
      ws["!images"].push({ 
      name: 'image' + index + '.png', 
      data: imgToDataUrl(image.element[0]), 
      opts: {base64: true}, 
      type: "png", 
      position: { 
       type: 'twoCellAnchor', 
       attrs: {editAs: 'oneCell'}, 
       from: {col: image.c, row: image.r}, 
       to: {col: image.c + 1, row: image.r + 1} 
      } 
      }); 
     }); 
     wb.Sheets[ws_name] = ws; 
    }]); 

テンプレートコード:

<div ng-controller="MyCtrl"> 
    <table id="table" border="1"> 
    <tr> 
     <td contenteditable="true"> 
     <img crossOrigin="Anonymous" src=""> 
     </td> 
    </tr> 
    </table> 
    <p id="exportxlsx" class="xport"><input type="submit" value="Export to XLSX!"></p> 
</div> 

私はhttps://cdnjs.cloudflare.com/ajax/libs/xlsx/0.11.14/xlsx.core.min.jshttps://rawgit.com/xSirrioNx/js-xlsx/master/xlsx.jsを交換した場合はエラーがスローされていないファイルがダウンロードされますが、何の画像:

http://jsfiddle.net/coolcatDev/ADukg/17028/

console.log(wb)には、Sheets->SheetJS->!relsはAngularJS例の中に欠落しています。

作業例: enter image description here 角度失敗例: enter image description here

答えて

関連する問題