码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 处理Blob打印Excel


    一、 说明

    当后端返回Blob二进制文件流,前端根据返回内容生成对应文件,生成a标签,利用a标签的下载特性来完成打印文件的下载。

    二、 使用示例

    // 引入封装请求方法
    import request from 'utils/request';
    const downloadDll = async (record) => {
        const res = await request(`/exportUrl`, {
          method: 'POST',
          responseType: 'blob',
          body: "请求参数"
        });
        if (res) {
           const file = new Blob([res], { type: 'application/vnd.ms-excel' }); // 解析文件
            const fileURL = URL.createObjectURL(file); // 生成文件地址
            const fileName = '文件名称.xls';
            const elink = document.createElement('a'); // 生成a标签
            elink.download = fileName; // a标签下载名
            elink.style.display = 'none'; // 设置a标签隐藏,不在页面展示
            elink.href = fileURL; // 设置a标签下载地址
            document.body.appendChild(elink); // 在body中添加a标签
            elink.click();  // 手动调用a标签点击下载属性
            URL.revokeObjectURL(elink.href); // 释放URL 对象
            document.body.removeChild(elink); // 在body中删除a标签
        }
      };
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    三、 注意

    • 请求的返回类型为responseType: blob
    • 实例化Blob时传第二个参数解析文件类型{ type: 'application/vnd.ms-excel' }

    四、 补充:下载PDF

    const file = new Blob([result], { 
    	type: 'application/pdf' }); // 解析文件
    const fileURL = URL.createObjectURL(file);  // 创建pdf文件
    const newwindow = window.open(fileURL, 'newwindow');  // 打开新的页面进行预览
    newwindow ? newwindow.print() : notification.error(
    { message: '当前窗口已被浏览器拦截,请手动设置浏览器!' }); // 判断是否成功打开
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    k8s的资源管理
    魔众题库系统 v7.5.0 连续增加题目,题目公开快捷操作
    Ros cartographer pure localization 自定位+重定位+导航
    AttributeError: module ‘tensorflow‘ has no attribute ‘__version__‘
    教育(edu)邮箱的价值
    苹果从成熟到落地,Apple Newton 背后的工程师们 | 历史上的今天
    双指针代码
    通过ffmpeg 下载在线的.m3u8格式视频
    大厂 Framework 面试必备 Handler&Binder 面试题
    计算机网络 一、概述
  • 原文地址:https://blog.csdn.net/IO14122/article/details/126361631
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号