提交 37d9d84c 编写于 作者: bo.dang's avatar bo.dang

下载优化

上级 27368773
...@@ -5,49 +5,49 @@ ...@@ -5,49 +5,49 @@
// data can be a string, Blob, File, or dataURL // data can be a string, Blob, File, or dataURL
function download(data, strFileName, strMimeType) { function download (data, strFileName, strMimeType) {
var self = window, // this script is only for browsers anyway... var self = window, // this script is only for browsers anyway...
u = "application/octet-stream", // this default mime also triggers iframe downloads u = "application/octet-stream", // this default mime also triggers iframe downloads
m = strMimeType || u, m = strMimeType || u,
x = data, x = data,
D = document, D = document,
a = D.createElement("a"), a = D.createElement("a"),
z = function(a){return String(a);}, z = function(a){return String(a);},
B = self.Blob || self.MozBlob || self.WebKitBlob || z, B = self.Blob || self.MozBlob || self.WebKitBlob || z,
BB = self.MSBlobBuilder || self.WebKitBlobBuilder || self.BlobBuilder, BB = self.MSBlobBuilder || self.WebKitBlobBuilder || self.BlobBuilder,
fn = strFileName || "download", fn = strFileName || "download",
blob, blob,
b, b,
ua, ua,
fr; fr;
//if(typeof B.bind === 'function' ){ B=B.bind(self); } //if(typeof B.bind === 'function' ){ B=B.bind(self); }
if(String(this)==="true"){ //reverse arguments, allowing download.bind(true, "text/xml", "export.xml") to act as a callback if(String(this)==="true"){ //reverse arguments, allowing download.bind(true, "text/xml", "export.xml") to act as a callback
x=[x, m]; x=[x, m];
m=x[0]; m=x[0];
x=x[1]; x=x[1];
} }
//go ahead and download dataURLs right away //go ahead and download dataURLs right away
if(String(x).match(/^data\:[\w+\-]+\/[\w+\-]+[,;]/)){ if(String(x).match(/^data\:[\w+\-]+\/[\w+\-]+[,;]/)){
return navigator.msSaveBlob ? // IE10 can't do a[download], only Blobs: return navigator.msSaveBlob ? // IE10 can't do a[download], only Blobs:
navigator.msSaveBlob(d2b(x), fn) : navigator.msSaveBlob(d2b(x), fn) :
saver(x) ; // everyone else can save dataURLs un-processed saver(x) ; // everyone else can save dataURLs un-processed
}//end if dataURL passed? }//end if dataURL passed?
try{ try{
blob = x instanceof B ? blob = x instanceof B ?
x : x :
new B([x], {type: m}) ; new B([x], {type: m}) ;
}catch(y){ }catch(y){
if(BB){ if(BB){
...@@ -55,11 +55,11 @@ function download(data, strFileName, strMimeType) { ...@@ -55,11 +55,11 @@ function download(data, strFileName, strMimeType) {
b.append([x]); b.append([x]);
blob = b.getBlob(m); // the blob blob = b.getBlob(m); // the blob
} }
} }
function d2b(u) { function d2b(u) {
var p= u.split(/[:;,]/), var p= u.split(/[:;,]/),
t= p[1], t= p[1],
...@@ -73,11 +73,11 @@ function download(data, strFileName, strMimeType) { ...@@ -73,11 +73,11 @@ function download(data, strFileName, strMimeType) {
return new B([uia], {type: t}); return new B([uia], {type: t});
} }
function saver(url, winMode){ function saver(url, winMode){
if ('download' in a) { //html5 A[download] if ('download' in a) { //html5 A[download]
a.href = url; a.href = url;
a.setAttribute("download", fn); a.setAttribute("download", fn);
a.innerHTML = "downloading..."; a.innerHTML = "downloading...";
...@@ -89,44 +89,44 @@ function download(data, strFileName, strMimeType) { ...@@ -89,44 +89,44 @@ function download(data, strFileName, strMimeType) {
}, 66); }, 66);
return true; return true;
} }
//do iframe dataURL download (old ch+FF): //do iframe dataURL download (old ch+FF):
var f = D.createElement("iframe"); var f = D.createElement("iframe");
D.body.appendChild(f); D.body.appendChild(f);
if(!winMode){ // force a mime that will download: if(!winMode){ // force a mime that will download:
url="data:"+url.replace(/^data:([\w\/\-\+]+)/, u); url="data:"+url.replace(/^data:([\w\/\-\+]+)/, u);
} }
f.src = url; f.src = url;
setTimeout(function(){ D.body.removeChild(f); }, 333); setTimeout(function(){ D.body.removeChild(f); }, 333);
}//end saver }//end saver
if (navigator.msSaveBlob) { // IE10+ : (has Blob, but not a[download] or URL) if (navigator.msSaveBlob) { // IE10+ : (has Blob, but not a[download] or URL)
return navigator.msSaveBlob(blob, fn); return navigator.msSaveBlob(blob, fn);
} }
if(self.URL){ // simple fast and modern way using Blob and URL: if(self.URL){ // simple fast and modern way using Blob and URL:
saver(self.URL.createObjectURL(blob), true); saver(self.URL.createObjectURL(blob), true);
}else{ }else{
// handle non-Blob()+non-URL browsers: // handle non-Blob()+non-URL browsers:
if(typeof blob === "string" || blob.constructor===z ){ if(typeof blob === "string" || blob.constructor===z ){
try{ try{
return saver( "data:" + m + ";base64," + self.btoa(blob) ); return saver( "data:" + m + ";base64," + self.btoa(blob) );
}catch(y){ }catch(y){
return saver( "data:" + m + "," + encodeURIComponent(blob) ); return saver( "data:" + m + "," + encodeURIComponent(blob) );
} }
} }
// Blob but not URL: // Blob but not URL:
fr=new FileReader(); fr=new FileReader();
fr.onload=function(e){ fr.onload=function(e){
saver(this.result); saver(this.result);
}; };
fr.readAsDataURL(blob); fr.readAsDataURL(blob);
} }
return true; return true;
} /* end download() */ } /* end download() */
...@@ -261,6 +261,7 @@ ...@@ -261,6 +261,7 @@
</template> </template>
<script> <script>
import {openLoading, closeLoading} from "../../utils/utils"; import {openLoading, closeLoading} from "../../utils/utils";
import download from "@/utils/download/download2";
let vm = null; let vm = null;
import BreadCrumb from "@/components/breadcrumb.vue"; import BreadCrumb from "@/components/breadcrumb.vue";
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册