1

问题

我想在 Javascript 中生成一个包含多个其他 ZIP 文件的 ZIP 文件。我使用 JSZIP,但我无法将 ZIP 文件添加到一个 ZIP 文件中。

例子

我有多个文本文件:

  • 播放器 1 - 文件 1.txt
  • 播放器 1 - 文件 2.txt
  • 播放器 2 - 文件 1.txt
  • 播放器 2 - 文件 2.txt

我想生成那个 ZIP 文件:

  • 例子.zip
    • 播放器 1.zip
      • 播放器 1 - 文件 1.txt
      • 播放器 1 - 文件 2.txt
    • 播放器 2.zip
      • 播放器 2 - 文件 1.txt
      • 播放器 2 - 文件 2.txt

谢谢您的帮助。

4

1 回答 1

1

小提琴:https ://mikethedj4.github.io/kodeWeave/editor/#ca2d1692722e8f6c321c322cd33ed246

经过数小时和失败的尝试,我终于让它与JSZip一起工作!

注意:我使用的是 JSZip v2.6.0,它目前已经过时,不能与发布时的当前版本 3.0 一起使用。

JavaScript

// Set Sample URL
document.getElementById("zipurl").value = "https://mikethedj4.github.io/kodeWeave/editor/zips/font-awesome.zip";

$(".loadzipurl").on("click", function() {
  if ( (!document.getElementById("zipurl").value) ) {
    // Do nothing
    alertify.error("Unable to perform operation as value is blank!");
  } else {
    if ( (document.getElementById("zipurl").value.toLowerCase().substring(0,7) === "http://" ) || (document.getElementById("zipurl").value.toLowerCase().substring(0,8) === "https://") ) {
      JSZipUtils.getBinaryContent(document.getElementById("zipurl").value, function(error, repoFiles) {
        if(error) {
          throw error // or handle err
        }

        var webAppZipBinary = repoFiles;

        // Download as Windows App
        JSZipUtils.getBinaryContent("https://mikethedj4.github.io/kodeWeave/editor/zips/YourLinApp.zip", function(err, data) {
          if(err) {
            throw err // or handle err
          }

          alertify.message("Creating application!");
          var zip = new JSZip();
          zip.load(data);

          // Your Web Application
          zip.folder("HELLOMOMMY/").load(webAppZipBinary);

          // For 32bit Windows Application
          zip.file("package.json", '{\n  "main"  : "index.html",\n  "name"  : "test",\n  "window": {\n      "toolbar" : false,\n      "icon"    : "app/icons/128.png",\n      "width"   : 1000,\n      "height"  : 600,\n      "position": "center"\n  }\n}');
          zip.file("index.html", '<!doctype html>\n<html>\n <head>\n    <title>test</title>\n    <style>\n      iframe {\n        position: absolute;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 100%;\n        overflow: visible;\n        border: 0;\n      }\n    </style>\n  </head>\n <body>\n    <iframe src="app/index.html"></iframe>\n  </body>\n</html>');

          // Export your application
          var content = zip.generate({type:"blob"});
          saveAs(content, "test-win.zip");
          return false;
        });
      });
    } else {
      alertify.error("Error! \"http://\" and \"https://\" urls are only supported!");
    }
  }
});

HTML

<input type="text" id="zipurl" placeholder="http://">
<button class="loadzipurl">Export Application</button>
于 2016-08-06T21:52:43.080 回答