我试图下载.obj文件,我从二进制顶点数组生成客户端。问题是有太多的顶点适合浏览器窗口内存
exportOBJ() {
var output = 'o object_export\n';
var i, j, k, l, x, y, z;
var vertices = this._vertices.array;
for (i = 0; i < vertices.length; i += 3) {
x = vertices[i];
y = vertices[i + 1];
z = vertices[i + 2];
output += 'v ' + x + ' ' + y + ' ' + z + '\n';
}
//Other data...
}
//保存方法
function (data) {
var blob = new Blob([data], { type: 'text/obj;charset=utf-8;' });
if (navigator.msSaveBlob) { // IE 10+
navigator.msSaveBlob(blob, filename);
} else {
var link = document.createElement("a");
if (link.download !== undefined) { // feature detection
// Browsers that support HTML5 download attribute
var url = URL.createObjectURL(blob);
link.setAttribute("href", url);
link.setAttribute("download", 'export.obj');
link.style.visibility = 'hidden';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
}
}
})
所以这适用于小顶点文件,但是当有许多顶点,如10M时,浏览器窗口崩溃。我研究过使用文件流,但据我所知,这不是客户端的。同样适用于https://github.com/jimmywarting/StreamSaver.js,我也需要能够上传。
在您的问题中提到的github项目中,有人提到当您的网站在https上运行时,它可以在客户端运行。只有当您的网站不是https时,它才会使用“中间人”策略。
因此,只要您的网站是https,您就可以使用服务工作者拦截URL获取请求,并下载内容。
顺便说一下,你提到的项目非常有用。谢谢。