js下載pdf

/*
 *downloadPdf 下載工具
 * url 下載路徑
 * name 保存的 名字
 * 
 * */
//download.js v3.0, by dandavis; 2008-2014. [CCBY2] see官網(wǎng) 地址http://danml.com/download.html
// data can be a string, Blob, File, or dataURL
function downloadFile(url, name) {
    var x = new XMLHttpRequest();
    x.open("GET", url, true);
    x.responseType = 'blob';
    x.onload = function(e) {
        download(x.response, name || 'shanyanwt.pdf', "image/png");
    };
    x.send();
 
}
 
function download(data, strFileName, strMimeType) {
 
    var self = window, // this script is only for browsers anyway...
        u = "application/octet-stream", // this default mime also triggers iframe downloads
        m = strMimeType || u,
        x = data,
        D = document,
        a = D.createElement("a"),
        z = function(a) {
            return String(a);
        },
 
        B = self.Blob || self.MozBlob || self.WebKitBlob || z,
        BB = self.MSBlobBuilder || self.WebKitBlobBuilder || self.BlobBuilder,
        fn = strFileName || "download",
        blob,
        b,
        ua,
        fr;
 
    //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
        x = [x, m];
        m = x[0];
        x = x[1];
    }
 
    //go ahead and download dataURLs right away
    if(String(x).match(/^data\:[\w+\-]+\/[\w+\-]+[,;]/)) {
        return navigator.msSaveBlob ? // IE10 can't do a[download], only Blobs:
            navigator.msSaveBlob(d2b(x), fn) :
            saver(x); // everyone else can save dataURLs un-processed
    } //end if dataURL passed?
 
    try {
 
        blob = x instanceof B ?
            x :
            new B([x], {
                type: m
            });
    } catch(y) {
        if(BB) {
            b = new BB();
            b.append([x]);
            blob = b.getBlob(m); // the blob
        }
 
    }
 
    function d2b(u) {
        var p = u.split(/[:;,]/),
            t = p[1],
            dec = p[2] == "base64" ? atob : decodeURIComponent,
            bin = dec(p.pop()),
            mx = bin.length,
            i = 0,
            uia = new Uint8Array(mx);
 
        for(i; i < mx; ++i) uia[i] = bin.charCodeAt(i);
 
        return new B([uia], {
            type: t
        });
    }
 
    function saver(url, winMode) {
 
        if('download' in a) { //html5 A[download]           
            a.href = url;
            a.setAttribute("download", fn);
            a.innerHTML = "downloading...";
            D.body.appendChild(a);
            setTimeout(function() {
                a.click();
                D.body.removeChild(a);
                if(winMode === true) {
                    setTimeout(function() {
                        self.URL.revokeObjectURL(a.href);
                    }, 250);
                }
            }, 66);
            return true;
        }
 
        //do iframe dataURL download (old ch+FF):
        var f = D.createElement("iframe");
        D.body.appendChild(f);
        if(!winMode) { // force a mime that will download:
            url = "data:" + url.replace(/^data:([\w\/\-\+]+)/, u);
        }
 
        f.src = url;
        setTimeout(function() {
            D.body.removeChild(f);
        }, 333);
 
    } //end saver 
 
    if(navigator.msSaveBlob) { // IE10+ : (has Blob, but not a[download] or URL)
        return navigator.msSaveBlob(blob, fn);
    }
 
    if(self.URL) { // simple fast and modern way using Blob and URL:
        saver(self.URL.createObjectURL(blob), true);
    } else {
        // handle non-Blob()+non-URL browsers:
        if(typeof blob === "string" || blob.constructor === z) {
            try {
                return saver("data:" + m + ";base64," + self.btoa(blob));
            } catch(y) {
                return saver("data:" + m + "," + encodeURIComponent(blob));
            }
        }
 
        // Blob but not URL:
        fr = new FileReader();
        fr.onload = function(e) {
            saver(this.result);
        };
        fr.readAsDataURL(blob);
    }
    return true;
} /* end download() */
export default {
    download,
    downloadFile
}
export {
    download,
    downloadFile
}

html

<button  @click="todownload(pdfurl)" >下載</button>
import {download} from '../../utils/download'
     async todownload( data){
      var x = new XMLHttpRequest();
      x.open("GET", data, true);
      x.responseType = 'blob';
      x.onload = function(e) {
        download(x.response, name || 'shanyanwt.pdf', "image/png");
      };
      x.send();
      return false
    },
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子兜叨,更是在濱河造成了極大的恐慌睡毒,老刑警劉巖宅静,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宋梧,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)虹脯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)奏候,“玉大人归形,你說(shuō)我怎么就攤上這事”怯桑” “怎么了暇榴?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)蕉世。 經(jīng)常有香客問(wèn)我蔼紧,道長(zhǎng),這世上最難降的妖魔是什么狠轻? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任奸例,我火速辦了婚禮,結(jié)果婚禮上向楼,老公的妹妹穿的比我還像新娘查吊。我一直安慰自己,他們只是感情好湖蜕,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布逻卖。 她就那樣靜靜地躺著,像睡著了一般昭抒。 火紅的嫁衣襯著肌膚如雪评也。 梳的紋絲不亂的頭發(fā)上炼杖,一...
    開(kāi)封第一講書(shū)人閱讀 51,604評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音盗迟,去河邊找鬼坤邪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛罚缕,可吹牛的內(nèi)容都是我干的艇纺。 我是一名探鬼主播,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼邮弹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼喂饥!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起肠鲫,我...
    開(kāi)封第一講書(shū)人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎或粮,沒(méi)想到半個(gè)月后导饲,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡氯材,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年渣锦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片氢哮。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡袋毙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出冗尤,到底是詐尸還是另有隱情听盖,我是刑警寧澤,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布裂七,位于F島的核電站皆看,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏背零。R本人自食惡果不足惜腰吟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望徙瓶。 院中可真熱鬧毛雇,春花似錦、人聲如沸侦镇。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)壳繁。三九已至始藕,卻和暖如春蒲稳,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背伍派。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工江耀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人诉植。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓祥国,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親晾腔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子舌稀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容