侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

js + Bolb实现文件流下载csv文件示例代码

前端  /  管理员 发布于 3个月前   188

在 Blob 对象出现之前,在 javascript 中一直没有比较好的方式处理二进制文件,自从有了 Blob 了,我们就可以使用它操作二进制数据了。

现在我们开始来理解下 Bolb 对象及它的文件流下载应用场景,话不多说了,来一起看看详细的介绍吧


创建 Blob 对象方式如下:

var blob = new Blob(dataArray, options);

dataArray: 

它是一个数组,它包含了要添加到 Blob 对象中的数据。数组可以是二进制对象或者字符串。

options :

是可选的对象参数,用于设置数组中数据的 MIME 类型。


创建一个 DOMString 对象的 Blob 对象。如下代码:

 var str = "<div>Hello World</div>";
 var blob = new Blob([str], {type: 'text/xml'});
 console.log(blob); // 输出:Blob {size: 22, type: "text/xml"}


理解 URL.createObjectURL 对象

window 对象的 URL 对象是用来将 blob 或 file 读取成一个 url 的。

    window.URL.createObjectURL(file / blob);

比如我现在结合上面的 blob 对象来生成一个 url 的简单 demo 实列如下所示:

    var str = "<div>Hello World</div>";
    var blob = new Blob([str], {type: '.csv, application/vnd.openxmlformats-        officedocument.spreadsheetml.sheet, application/vnd.ms-excel'});
    console.log(blob);
    const url3 = window.URL.createObjectURL(blob);
    console.log(url3);

如上代码第一个打印 blob 变量值如下:

    Blob {size: 22, type: ".csv, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel"}

打印第二个 url3 变量值信息如下:

    blob:null/2c75a56e-0104-4572-bc19-391d3bf93d9d


理解 HTML5 中 a 标签的 download 属性

HTMl5 中给 a 标签新增了一个 download 属性,只要我们设置该属性值,那么点击该链接时浏览器不会打开新链接,而是会直接下载文件,并且文件名就是 download 的属性值。


因此结合这个特点,我们就可以简单的实现文件流下载文件了,我们首先在原来的代码基础之上,再动态创建一个 a 链接,然后把该 a 标签的样式设置 none, 该链接的 href 属性 就是我们上面是有

window.URL.createObjectURL (blob); 

生成的 url,然后我们把 a 链接的 download 属性设置下,该属性值就是我们的下载文件的文件名。

最后触发点击功能即可下载了。如下代码:

        var str = "<div>Hello World</div>";
        var blob = new Blob([str], {type: '.csv, application/vnd.openxmlformats-        officedocument.spreadsheetml.sheet, application/vnd.ms-excel'});
        console.log(blob);
        const url3 = window.URL.createObjectURL(blob);
        console.log(url3);
        var filename = '文件流下载' + '.csv';
        const link = document.createElement('a');
        link.style.display = 'none';
        link.href = url3;
        link.setAttribute('download', filename);
        document.body.appendChild(link);
        link.click();

  • 上一条:
    在go语言中设置或添加头http.ResponseWriter示例
    下一条:
    Laravel 9.44版本发布
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 如何优雅处理async await错误推荐:await-to-js库(0个评论)
    • lodash工具库(0个评论)
    • nginx + vue配置实现同域名下不同路径访问不同项目(0个评论)
    • 在js中使用URL类用来解析处理URL的示例代码(0个评论)
    • js中动画事件:requestAnimationFrame、transitionend、animation...(0个评论)
    • 近期文章
    • 如何优雅处理async await错误推荐:await-to-js库(0个评论)
    • lodash工具库(0个评论)
    • 在Laravel项目中使用中间件方式统计用户在线时长功能代码示例(0个评论)
    • 在Laravel中构建业务流程模型(0个评论)
    • windows系统中安装FFMpeg及在phpstudy环境php7.3 + php-ffmpeg扩展的使用流程步骤(0个评论)
    • 在go语言中对浮点的数组、切片(slice)进行正向排序和反向排序(0个评论)
    • 在go语言中对整数数组、切片(slice)进行排序和反向排序(0个评论)
    • 在go语言中对字符串数组、切片(slice)进行排序和反向排序(0个评论)
    • 最新国内免注册ChatGPT体验站_ChatGPT镜像站访问链接地址2023/3/28持续更新(0个评论)
    • 在Laravel项目中的实现无密码认证之:发送邮箱链接授权(0个评论)
    • 近期评论
    • 博主 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 @ xiaoB 你只管努力,剩下的叫给天意;天若有情天亦老,..
    • xiaoB 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 会不会春节放假后又阳一次?..
    • BUG4 在

      你翻墙过吗?国内使用vpn翻墙可能会被网警抓,你需了解的事中评论 不是吧?..
    • 博主 在

      go语言+beego框架中获取get,post请求的所有参数中评论 @ t1  直接在router.go文件中配就ok..
    • Jade 在

      如何在MySQL查询中获得当月记录中评论 Dear zongscan.com team, We can skyroc..
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客