【JavaScript】IEの場合のdownload属性の代替

【JavaScript】IEの場合のdownload属性の代替

IEの場合、aタグのdownload属性が効かず、ファイルのダウンロードできなかったため、その代替案についての覚え書きです(Drupalネタではないです)。

download属性

Excelファイルをダウンロードできるように、以下のようなリンクを作成し、ファイルがダウンロードできることを確認していたのですが、


<a download="Test.xlsx" href="/download/Test.xlsx">Test.xlsx</a>

IEの場合、これではダウンロードできないとのことで、その対応結果を以下に記します。

JavaScriptでの対応

ググったところ、JavaScriptで画像をダウンロードしたいの記事によると、JavaScriptを使えば、IEでもリンクからファイルのダウンロードができるとのこと。

上記の記事を参考にして、以下のJavaScriptを記述。


function downloadFile(uri,fileName,id) {

    // IEはdownload属性が効かないので分岐
    if (window.navigator.msSaveOrOpenBlob) {
        let xhr = new XMLHttpRequest();
        xhr.open('GET', uri);
        xhr.responseType = 'blob';
        xhr.onloadend = function() {
            if (xhr.status !== 200) {
                return false;
            }
            window.navigator.msSaveOrOpenBlob(xhr.response, fileName);
        };
        xhr.send();
    } else {
        let link = document.getElementById(id);
        link.href = uri;
        link.download = fileName;
    }
}


HTMLは、以下のように記述を変更し、IEでもファイルをダウンロードできるようになりました。


<a id="download1" href="javascript:void(0);" onclick="downloadFile('/download/Test.xlsx','Test.xlsx','download1');">Test.xlsx</a>

カテゴリー

コメント

dark internet <a href="https://privatedarkwebmarkets.shop/ ">tor markets 2022 </a>
名前
Crisscunc
dark web drug marketplace <a href="https://tordarkwebmarket.com/ ">dark markets </a>
名前
Charlescob
tor market links <a href="https://tordarknetmarkets2023.shop/ ">dark web market list </a>
名前
Robertfup
dark web sites <a href="https://kingdomarket.link/ ">dark market 2023 </a>
名前
HaroldHot
darkmarket 2023 <a href="https://blackmarketweb.com/ ">darknet drug links </a>
名前
RobertKix
dark web search engines <a href="https://thedarkwebmarket.com/ ">darknet sites </a>
名前
SmittMef
onion market <a href="https://tor-market-darknet.shop/ ">darknet drugs </a>
名前
Wendellpog
deep dark web <a href="https://ccannahome-market.shop/ ">darknet websites </a>
名前
HectorDer
darknet market list <a href="https://tordarknetmarketlist.link/ ">dark web drug marketplace </a>
名前
Josephanarm
tor markets 2022 <a href="https://tordarkmarketurl.shop/ ">dark web search engines </a>
名前
CraigAgeni
darknet market links <a href="https://tor-markets-darkweb.com/ ">tor marketplace </a>
名前
Sirket
darknet markets 2023 <a href="https://privatedarkwebmarket.link/ ">darknet marketplace </a>
名前
WilliamRip
onion market <a href="https://torwebmarketplace.link/ ">tor markets </a>
名前
Dannyquord
dark markets 2023 <a href="https://tordarkwebmarketlinks.com/ ">tor dark web </a>
名前
DavidDes
how to write an argumentative essay <a href="https://collegeessaywritertld.net/">writing an argument essay</a> in preparing to write a research-based expository essay, the writer must:
名前
ABNOSEKS
dark markets 2022 <a href="https://tordarkwebmarketlink.link/ ">deep web search </a>
名前
Patrickhuple
dark websites <a href="https://privatedarknetmarkets.shop/ ">deep web drug markets </a>
名前
Davidinodo
tor dark web <a href="https://thetormarket.link/ ">tor markets </a>
名前
Ralphzet
dark internet <a href="https://darknetmarketslist.link/ ">dark web link </a>
名前
BrianFew
onion market <a href="https://tor-market-darknet.com/ ">dark web search engines </a>
名前
Granttromo
dark market 2022 <a href="https://tor-market-darkweb.shop/ ">darkmarket </a>
名前
Danired
blackweb <a href="https://tor-markets-darknet.link/ ">dark market list </a>
名前
Teddred
dark markets 2022 <a href="https://thedarkmarketpoint.link/ ">dark web market links </a>
名前
Tornaddib
darknet drug store <a href="https://tordarkwebmarkets2022.link/ ">dark web access </a>
名前
JuliusEsobe
drug markets onion <a href="https://tor-markets2023.shop/ ">dark market 2022 </a>
名前
WilliamNaw
tor market url <a href="https://tor-darkmarket-online.com/ ">darknet market lists </a>
名前
JamesStaiz
deep dark web <a href="https://tor-darkmarket-online.shop/ ">dark web search engines </a>
名前
CharlesNuh
deep web links <a href="https://tordarknetmarket24.link/ ">deep web drug markets </a>
名前
Georgelouse
deep web sites <a href="https://tordarknetmarketlist.shop/ ">deep web drug url </a>
名前
JamesseM
darkmarket list <a href="https://tordarkmarketurl.com/ ">dark web markets </a>
名前
Ronaldevica
dark net <a href="https://privatedarknetmarkets.com/ ">dark markets </a>
名前
Baaket
dark web market <a href="https://tormarketwebxx.com/ ">dark market onion </a>
名前
DonaldDic
darkmarket 2023 <a href="https://thedarknetmarket.com/ ">how to access dark web </a>
名前
CorryViarD
darknet seiten <a href="https://heinekenexpress.link/ ">darknet drug market </a>
名前
Stevejails
dark web websites <a href="https://tordarkmarketweb.shop/ ">tor markets 2022 </a>
名前
Geraldhopay
deep web links <a href="https://cannahome-market.shop/ ">darknet drug links </a>
名前
JackieDuart
dark market <a href="https://tordarkwebmarketlinks.shop/ ">darknet markets </a>
名前
TimmyMeexy
darknet drugs <a href="https://torwebdarknet.link/ ">drug markets dark web </a>
名前
Randykew
dark markets 2023 <a href="https://asap-market.shop/ ">free dark web </a>
名前
Michaelloush
tor market url <a href="https://privatedarkwebmarkets.com/ ">dark markets 2023 </a>
名前
Jancal
darkweb marketplace <a href="https://kkingdomarket.link/ ">deep web drug links </a>
名前
Matthewgek
darkweb marketplace <a href="https://tormarketwebxx.link/ ">deep web drug url </a>
名前
JasonGribe
dark web markets <a href="https://thedarknetmarket.shop/ ">dark market 2022 </a>
名前
ADElugh
deep web drug links <a href="https://aasapmarket.com/ ">dark markets </a>
名前
Brandendet
darknet websites <a href="https://tor-markets-darknet.com/ ">deep web drug links </a>
名前
FrankHuluh
dark web market links <a href="https://thedarkwebmarket.link/ ">darkmarket link </a>
名前
Hanstulge
tor darknet <a href="https://tordarkweblist.shop/ ">darkmarkets </a>
名前
BrandonWaype
darkweb marketplace <a href="https://tordarkmarketweb.link/ ">dark web access </a>
名前
DamonLat
darkmarket url <a href="https://tor-marketplace24.link/ ">darknet links </a>
名前
Danielred
darknet drug market <a href="https://tordarkwebmarketlink.com/ ">darkmarket link </a>
名前
Richardvak

コメントを追加

CAPTCHA
この質問はあなたが人間の訪問者であるかどうかをテストし、自動化されたスパム送信を防ぐためのものです。
画像CAPTCHA
画像内に表示されている文字列を入力してください。