A minap futottam bele a problémába, hogy böngészőből kellene letölteni egy frontenden megszűrt és csak ideiglenesen ott létező listát. Gyorsan rákerestem a megoldásra és a következő javascript kódot találtam hozzá:
function createDownloadLink(anchorSelector, str, fileName){ if(window.navigator.msSaveOrOpenBlob) { var fileData = [str]; blobObject = new Blob(fileData); $(anchorSelector).click(function(){ window.navigator.msSaveOrOpenBlob(blobObject, fileName); }); } else { var url = "data:text/plain;charset=utf-8," + encodeURIComponent(str); $(anchorSelector).attr("download", fileName); $(anchorSelector).attr("href", url); } } $(function () { // fájlt tartalma var str = "hi,file"; createDownloadLink("#export",str,"file.txt"); });
A letöltő funkcionalitást a createDownloadLink függvény meghívásával linkeljük a html-ünkben található linkhez. Egyetlen megkötés van még. A linkünknek kell lennie egy download attributumának. Böngészőfüggetlen működéshez kell. A kód az alábbi böngészőkben működik: IE11+, Firefox 25+ és Chrome 30. A 9. sorban megadott fájl formátummal és karakterkódolással kedvünk szerint játszhatunk. Én sima text és csv fájllal próbáltam. Jelentem működik 🙂
<a id="export" class="myButton" download="" href="#">export</a>
Így kellene kinéznie a linkünknek. Természetesen a szöveg és a class bátran cserélhető.