HTML5にキャンバスがあり、非常に長いdataURLになる可能性があります(Chromeに移動しようとするとChromeがクラッシュするのに十分な長さです)。そのため、JSZipを使用して画像をzip形式で保存しようとしています。私は次の2つのことを試しました:
var zip = new JSZip();
var savable = new Image();
savable.src = canvas.toDataURL();
zip.file("image.png", savable, {base64: true});
var content = zip.generate();
var blobLink = document.getElementById('blob');
blobLink.download = "image.zip";
blobLink.href = window.URL.createObjectURL(zip.generate({type:"blob"}));
これにより、次のエラーが発生します。
Uncaught TypeError: Object #<HTMLImageElement> has no method 'replace'
私もこれを試しました:
var zip = new JSZip();
zip.file("image.png", canvas.toDataURL(), {base64: true});
var content = zip.generate();
var blobLink = document.getElementById('blob');
blobLink.download = "image.zip";
blobLink.href = window.URL.createObjectURL(zip.generate({type:"blob"}));
それは機能しているように見えますが、zip内の画像は無効です。画像を正しく保存するにはどうすればよいですか?