来源:未知 时间:2021-09-10 19:03 作者:小飞侠 阅读:次
[导读] 今天带来js一款前端下载插件,js插件_文件导出插件FileSaver.js 插件描述:FileSaver.js是一款基于HTML5完成文件保存插件,它可以帮你直接从网页中导出多种格式文件。 FileSaver.js使用说明...
|
今天带来js一款前端下载插件,js插件_文件导出插件FileSaver.js
插件描述:FileSaver.js是一款基于HTML5完成文件保存插件,它可以帮你直接从网页中导出多种格式文件。 预览:http://res.zixuephp.com/js/FileSaver/index.xhtml FileSaver.js使用说明实现浏览器端生成并保存文件的 JavaScript 库 FileSaver.js 使用说明: 首先引入 JavaScript 文件: <script src="path/FileSaver.js"/> 保存成文本文件,需要先将保存内容转二进制,js原生提供 Blob方法可直接使用,第二个参数就是文件名. var blob = new Blob(["Hello, world!"], {type: "text/plain;charset=utf-8"});
saveAs(blob, "hello world.txt");保存成图片,需要利用canvas导出 toBlob 方法。 var canvas = document.getElementById("my-canvas"),
ctx = canvas.getContext("2d");
// draw to canvas...
// 这里绘制canvas相关操作 ctx. ...,比如把需要保存的图片导入到canvas等
// draw to canvas...
canvas.toBlob(function(blob) {
saveAs(blob, "pretty image.png");
});以下就是各大浏览器支持支持的浏览器:
插件源码FileSaver.js:/*! @source http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js */
var saveAs = saveAs || function(e) {
"use strict";
if (typeof e === "undefined" || typeof navigator !== "undefined" && /MSIE [1-9]\./.test(navigator.userAgent)) {
return
}
var t = e.document
, n = function() {
return e.URL || e.webkitURL || e
}
, r = t.createElementNS("http://www.w3.org/1999/xhtml", "a")
, o = "download"in r
, a = function(e) {
var t = new MouseEvent("click");
e.dispatchEvent(t)
}
, i = /constructor/i.test(e.HTMLElement) || e.safari
, f = /CriOS\/[\d]+/.test(navigator.userAgent)
, u = function(t) {
(e.setImmediate || e.setTimeout)(function() {
throw t
}, 0)
}
, s = "application/octet-stream"
, d = 1e3 * 40
, c = function(e) {
var t = function() {
if (typeof e === "string") {
n().revokeObjectURL(e)
} else {
e.remove()
}
};
setTimeout(t, d)
}
, l = function(e, t, n) {
t = [].concat(t);
var r = t.length;
while (r--) {
var o = e["on" + t[r]];
if (typeof o === "function") {
try {
o.call(e, n || e)
} catch (a) {
u(a)
}
}
}
}
, p = function(e) {
if (/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(e.type)) {
return new Blob([String.fromCharCode(65279), e],{
type: e.type
})
}
return e
}
, v = function(t, u, d) {
if (!d) {
t = p(t)
}
var v = this, w = t.type, m = w === s, y, h = function() {
l(v, "writestart progress write writeend".split(" "))
}, S = function() {
if ((f || m && i) && e.FileReader) {
var r = new FileReader;
r.onloadend = function() {
var t = f ? r.result : r.result.replace(/^data:[^;]*;/, "data:attachment/file;");
var n = e.open(t, "_blank");
if (!n)
e.location.href = t;
t = undefined;
v.readyState = v.DONE;
h()
}
;
r.readAsDataURL(t);
v.readyState = v.INIT;
return
}
if (!y) {
y = n().createObjectURL(t)
}
if (m) {
e.location.href = y
} else {
var o = e.open(y, "_blank");
if (!o) {
e.location.href = y
}
}
v.readyState = v.DONE;
h();
c(y)
};
v.readyState = v.INIT;
if (o) {
y = n().createObjectURL(t);
setTimeout(function() {
r.href = y;
r.download = u;
a(r);
h();
c(y);
v.readyState = v.DONE
});
return
}
S()
}
, w = v.prototype
, m = function(e, t, n) {
return new v(e,t || e.name || "download",n)
};
if (typeof navigator !== "undefined" && navigator.msSaveOrOpenBlob) {
return function(e, t, n) {
t = t || e.name || "download";
if (!n) {
e = p(e)
}
return navigator.msSaveOrOpenBlob(e, t)
}
}
w.abort = function() {}
;
w.readyState = w.INIT = 0;
w.WRITING = 1;
w.DONE = 2;
w.error = w.onwritestart = w.onprogress = w.onwrite = w.onabort = w.onerror = w.onwriteend = null;
return m
}(typeof self !== "undefined" && self || typeof window !== "undefined" && window || this.content);
if (typeof module !== "undefined" && module.exports) {
module.exports.saveAs = saveAs
} else if (typeof define !== "undefined" && define !== null && define.amd !== null) {
define("FileSaver.js", function() {
return saveAs
})
}
|
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com