码迷,mamicode.com
首页 > Web开发 > 详细

js不打开直接下载txt文件

时间:2020-06-25 11:52:04      阅读:442      评论:0      收藏:0      [点我收藏+]

标签:file   ===   获取文件   tin   UNC   new   func   class   cli   

    /**
     * 获取页面文件名
     * @param url 文件url
     */
    function downloadUrlFile(url) {
        url = url.replace(/\\/g, ‘/‘);
        const xhr = new XMLHttpRequest();
        xhr.open(‘GET‘, url, true);
        xhr.responseType = ‘blob‘;
        //xhr.setRequestHeader(‘Authorization‘, ‘Basic a2VybWl0Omtlcm1pdA==‘);
        xhr.onload = () => {
            if (xhr.status === 200) {
                // 获取文件blob数据并保存
                var fileName = getFileName(url);
                saveAs(xhr.response, fileName);
            }
        };

        xhr.send();
    }

    /**
     * URL方式保存文件到本地
     * @param data 文件的blob数据
     * @param name 文件名
     */
    function saveAs(data, name) {
        var urlObject = window.URL || window.webkitURL || window;
        var export_blob = new Blob([data]);
        var save_link = document.createElementNS(‘http://www.w3.org/1999/xhtml‘, ‘a‘)
        save_link.href = urlObject.createObjectURL(export_blob);
        save_link.download = name;
        save_link.click();
    }

    /**
     * 根据文件url获取文件名
     * @param url 文件url
     */
    function getFileName(url) {
        var num = url.lastIndexOf(‘/‘) + 1
        var fileName = url.substring(num)
            //把参数和文件名分割开
        fileName = decodeURI(fileName.split("?")[0]);
        return fileName;
    }

  下载文件时直接调用:

downloadUrlFile(‘下载地址.txt‘);

  

js不打开直接下载txt文件

标签:file   ===   获取文件   tin   UNC   new   func   class   cli   

原文地址:https://www.cnblogs.com/weixiaofantasy/p/13191184.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!