js不打开直接下载txt文件

    /**
     * 获取页面文件名
     * @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');

  

posted @ 2020-06-25 10:00  微笑范特西  阅读(1768)  评论(0编辑  收藏  举报