最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 前端 文件打包下载 - 掘金

    正文概述 掘金(乌龙茶不甜)   2021-10-26   668

    小知识,大挑战!本文正在参与「程序员必备小知识」创作活动

    本文已参与 「掘力星计划」 ,赢取创作大礼包,挑战创作激励金。

    前端下载文件

    前端下载文件的几种方式

    1. window.location.href
    2. window.open
    3. <a>标签

    以上下载方式在下载浏览器无法识别的文件时均可行,但如果遇到浏览器可以直接解析文件,如html,jpg,png等,则不会触发浏览器的文件下载,而是被浏览器直接解析并展示,遇到这种情况,我们可以使用<a>标签的download属性进行下载即可。

    <a href="/images/a.jpg" download="photo">
    

    有时需要js来触发下载,这种情况下我们可以通过动态创建a标签来解决。

    const a = document.createElement('a');
    a.href = downLoadUrl;
    a.download = downLoadUrl;
    a.click();
    return false;
    

    但是如果需要下载打包后的压缩文件,解决方案有多种,可以在服务端打包后返回下载url,前端通过<a>标签下载,亦或是前端去请求每个文件,打包后再下载,为了减轻服务端压力,这次需要在WEB端实现多文件的打包下载。

    安装依赖

    jszip

    JSZip 是一个用于创建、读取和编辑 .zip 文件的 javascript 库,具有可爱而简单的 API。

    stuk.github.io/jszip/

    demo

    var zip = new JSZip();
    zip.file("Hello.txt", "Hello World\n");
    var img = zip.folder("images");
    img.file("smile.gif", imgData, {base64: true});
    zip.generateAsync({type:"blob"})
    .then(function(content) {
        // see FileSaver.js
        saveAs(content, "example.zip");
    });
    

    Support

    OperaFirefoxSafariChromeInternet ExplorerNode.js
    YesYesYesYesYesYesTested with the latest versionTested with 3.0 / 3.6 / latest versionTested with the latest versionTested with the latest versionTested with IE 6 / 7 / 8 / 9 / 10Tested with node.js 0.10 / latest version


    file-saver

    FileSaver.js 是在客户端保存文件的解决方案,非常适合在客户端生成文件的 Web 应用程序

    github.com/eligrey/Fil…

    demo:

    import { saveAs } from 'file-saver';
    
    // Saving text
    var blob = new Blob(["Hello, world!"], {type: "text/plain;charset=utf-8"});
    FileSaver.saveAs(blob, "hello world.txt");
    
    
    // Saving URLs
    FileSaver.saveAs("https://httpbin.org/image", "image.jpg");
    

    Supported Browsers

    BrowserConstructs asFilenamesMax Blob SizeDependencies
    Firefox 20+BlobYes800 MiBNoneFirefox < 20data: URINon/aBlob.jsChromeBlobYes2GBNoneChrome for AndroidBlobYesRAM/5NoneEdgeBlobYes?NoneIE 10+BlobYes600 MiBNoneOpera 15+BlobYes500 MiBNoneOpera < 15data: URINon/aBlob.jsSafari 6.1+*BlobNo?NoneSafari < 6data: URINon/aBlob.jsSafari 10.1+BlobYesn/aNone

     

    代码实现

    template

    <el-button class="button success" @click="downloadPhoto">批量下载</el-button>
    

    script

    <script>
    import JSZip from 'jszip'
    import axios from 'axios'
    import { saveAs } from 'file-saver'
    
    
    export default {
      name: 'Download',
      data() {
        return {
          fileList:[
            'https://xxx/xxx/xxx.jpg',
            'https://xxx/xxx/xxx.jpg',
            'https://xxx/xxx/xxx.mp4',
          ]
        }
      },
      methods: {
        // 批量下载
        downloadPhoto() {
          // 获取文件流
          const getFile = (url) => {
            return new Promise((resolve, reject) => {
              axios
                .get(url, {
                  responseType: 'arraybuffer',
                })
                .then((res) => {
                  resolve(res.data)
                })
                .catch((err) => {
                  reject(err.toString())
                })
            })
          }
          // 创建JSZip实例
          const zip = new JSZip()
          // promise对象
          const promises = []
          // 创建下载列表
          const downList = this.fileList
          // 生成每个文件
          downList.forEach((v) => {
            // 获取文件名
            const fileName = v.split('/').slice(-1)
            // 生成promise
            const promise = getFile(v).then((res) => {
              zip.file(fileName, res)
            })
            promises.push(promise)
          })
          // 异步处理
          Promise.all(promises).then(() => {
            // 生成二进制流
            zip
              .generateAsync({
                type: 'blob',
              })
              .then((content) => {
                saveAs(content, this.order.task.title)
              })
          })
        },
      }
    }
    
    
    </script>
    

     

    实现效果:

    前端 文件打包下载 - 掘金

    前端 文件打包下载 - 掘金


    END

    「欢迎在评论区讨论,掘金官方将在掘力星计划活动结束后,在评论区抽送100份掘金周边,抽奖详情见活动文章」。


    起源地下载网 » 前端 文件打包下载 - 掘金

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元