zoukankan      html  css  js  c++  java
  • 各种下载文件方式总结

    文件下载有多种方式,链接跳转方式下载,打开新页面下载,ajax下载文件。

    以前ajax是不能下载文件的,现在的xhr2版本支持blob,可以将文件下载到内存中,然后弹出保存框,保存到本地。

    这样不能下载太大的文件,内存会被撑爆。新的fetch Api也可以下载文件。

    示例如下:

    1. 跳转下载

    function location_download(){
         location.href = '/file/build';
    }

    2. 超链接下载(可自由调整为本页下载或新开页面下载)

    <a class="btn" download="data.zip" target="_blank" href="/file/build">
       超链接直接下载
    </a>

    3. 模拟超链接下载

    function simulateA_download() {
        var a = document.createElement('a');
        a.href = '/file/build';
        //文件名无效
        a.download = 'data.zip';
        document.body.appendChild(a);
        a.click()
        document.body.removeChild(a);
    }

    4. 原生xhr下载

    function ajax_download(){
        var url = '/file/build';
        var xhr = new XMLHttpRequest();
        xhr.open('GET', url, true);    // 也可以使用POST方式,根据接口
        xhr.responseType = "blob";  // 返回类型blob
        // 定义请求完成的处理函数,请求前也可以增加加载框/禁用下载按钮逻辑
        xhr.onload = function () {
            // 请求完成
            if (this.status === 200) {
                // 返回200
                var blob = this.response;
                var reader = new FileReader();
                reader.readAsDataURL(blob);  // 转换为base64,可以直接放入a表情href
                reader.onload = function (e) {
                    // 转换完成,创建一个a标签用于下载
                    var a = document.createElement('a');
                    //文件名有效
                    a.download = 'data.zip';
                    //会造成跳转到空白页,解决方案???
                    a.href = e.target.result;
                    a.target = '_self';
                    document.querySelector("body").appendChild(a);  // 修复firefox中无法触发click
                    a.click();
                    a.parentNode.remove();
                }
            }
        };
        // 发送ajax请求
        xhr.send()
    }

    5. axios下载

    function axios_download(){
        let url = '/file/build';
        let fileName = 'data_axios.zip';
        let type = fileName;
    
        return axios({
            method: 'get',
            url: url,
            responseType: 'blob',
            headers: {
                'content-disposition': `attachment;filename=${type}`,
                'content-type': 'application/x-download;charset=utf-8'
            }
        })
        .then(res => {
            const blob = new Blob([res.data], {type: type})
            const url = window.URL.createObjectURL(blob)
            const link = document.createElement('a')
            link.style.display = 'none'
            link.href = url
            //文件名有效
            link.setAttribute('download', fileName)
            document.body.appendChild(link)
            link.click()
            document.body.removeChild(link)
        })
    }

    6. superagent下载

    function superagent_download(){
        let url = '/file/build';
        let fileName = 'data_super.zip';
        let type = fileName;
    
        return superagent.get(url)
                            .set('content-disposition', `attachment;filename=${type}`)
                            .set('content-type', 'application/x-download;charset=utf-8')
                            .type('blob')
                            .then(res => {
                            const blob = new Blob([res.data], {type: type})
                            const url = window.URL.createObjectURL(blob)
                            const link = document.createElement('a')
                            link.style.display = 'none'
                            link.href = url
                            //文件名有效
                            link.setAttribute('download', fileName)
                            document.body.appendChild(link)
                            link.click()
                            document.body.removeChild(link)
                        })
                            
    }

    7. fetch下载

    function fetch_download() { 
        //可以先提示'文件下载中...',这样在下载框弹出之前,用户体验会好很多
        var url = "/file/build"; 
        fetch(url).then(res => res.blob().then(blob => { 
            var a = document.createElement('a'); 
            var url = window.URL.createObjectURL(blob);   // 获取 blob 本地文件连接 (blob 为纯二进制对象,不能够直接保存到磁盘上)
            var filename = res.headers.get('Content-Disposition');
            a.href = url; 
            a.download = filename.split('filename=')[1];
            a.click(); 
            window.URL.revokeObjectURL(url); 
            //提示'下载完成'; 
        })); 
    }

     8. 构造form下载

    function form_download(values){
        let url = '/file/build';
        try{
            let form = document.createElement('form');
            //用target指向iframe会打开新页面,原因是?????
            //form.target = 'ifr-down';
            form.action = url;
            form.method = 'get';
    
            if(values && typeof values == 'object'){
                Object.keys(values).forEach(item => {
                    form.insertAdjacentHTML('beforeend', `<input type="hidden" name="${item}" value="${values[item]}"/>`);
                })
            }
    
            let iframe = document.createElement('iframe');
            iframe.id = 'ifr-down';
            iframe.style = 'display:none';
            iframe.src = "about:blank";
            iframe.onload = function(){
                iframe.onload = null;
                //document.body.removeChild(form);
                //document.body.removeChild(iframe);
            }
            //document.body.appendChild(iframe);
            document.body.appendChild(form);
            form.submit();
        }
        catch(e){
            console.log(e);
        }
    }

    参考:https://www.cnblogs.com/YMaster/p/7707989.html

             https://segmentfault.com/a/1190000022255080

             https://www.jb51.net/article/122797.htm

  • 相关阅读:
    div+css 遮罩层
    高可用开源方案Heartbeat vs Keepalived
    nginx+keepalive 实现高可用负载均衡方案
    KeepAlive详解
    (转)高可用可伸缩架构实用经验谈 ---- 重要
    OpenStack与KVM的区别与联系
    架构师于小波:魅族实时消息推送架构
    抛开flash,自己开发实现C++ RTMP直播流播放器
    (转)C++实现RTMP协议发送H.264编码及AAC编码的音视频,摄像头直播
    (转)OC学习笔记 @property的属性 strong 和 weak 理解
  • 原文地址:https://www.cnblogs.com/mengff/p/13448550.html
Copyright © 2011-2022 走看看