当前位置: 首页 > news >正文

js直接下载附件和通过blob数据类型下载文件

js下载文件方式有使用a标签的,也有直接用window.open的,还有用form表单的;这里采用的是a标签的下载方式,一种是url直接下载,另一种是文件的blob数据类型进行下载。
文件blob数据类型的获取一般是后端返回文件的二进制流,前端通过请求工具获取为blob数据类型进行下载;也可以这直接通过ajax或fetch等将url转化为blob数据类型,一些特殊的附件直接通过url下载,浏览器可能会将其打开,如:pdf。

话不多说直接上代码:

一、url直接下载文件

/*** 文件url直接下载* @param {String} path 下载链接* @param {*} fileName 下载文件名称, 无文件名默认取url后面名称*/
const downloadUrl = (path, fileName) => {if(!path) return;const a = document.createElement("a");a.setAttribute("href", path);a.setAttribute("download", fileName);a.setAttribute("target", "_blank");const clickEvent = document.createEvent("MouseEvents");clickEvent.initEvent("click", true, true);a.dispatchEvent(clickEvent);
};

二、文件blob数据类型下载文件

/*** 文件blob数据格式进行下载* @description 文件下载* @param {String} blob  文件blob数据* @param {String} fileName 下载文件名*/
const downloadBlobUrl = function (blob, fileName = "") {if (!blob) return;if ("download" in document.createElement("a")) {// 非IE下载let link = document.createElement("a");if (window.URL) {link.href = window.URL.createObjectURL(blob);} else {link.href = window.webkitURL.createObjectURL(blob);}link.download = fileName;document.body.appendChild(link);link.click();link.remove();} else {// IE10+下载navigator.msSaveBlob(blob, fileName);}
};

需要的上方自取,有疑问或者其他问题欢迎评论沟通,也可加wx沟通账号与用户名一致

相关文章:

js直接下载附件和通过blob数据类型下载文件

js下载文件方式有使用a标签的,也有直接用window.open的,还有用form表单的;这里采用的是a标签的下载方式,一种是url直接下载,另一种是文件的blob数据类型进行下载。 文件blob数据类型的获取一般是后端返回文件的二进制流…...

第2章-神经网络的数学基础——python深度学习

第2章 神经网络的数学基础 2.1 初识神经网络 我们来看一个具体的神经网络示例,使用 Python 的 Keras 库 来学习手写数字分类。 我们这里要解决的问题是, 将手写数字的灰度图像(28 像素28 像素)划分到 10 个类别 中(0…...

【Docker】Docker学习⑧ - Docker仓库之分布式Harbor

【Docker】Docker学习⑧ - Docker仓库之分布式Harbor 一、Docker简介二、Docker安装及基础命令介绍三、Docker镜像管理四、Docker镜像与制作五、Docker数据管理六、网络部分七、Docker仓库之单机Dokcer Registry八、 Docker仓库之分布式Harbor1 Harbor功能官方介绍2 安装Harbor…...

一行命令在 wsl-ubuntu 中使用 Docker 启动 Windows

在 wsl-ubuntu 中使用 Docker 启动 Windows 0. 背景1. 验证我的系统是否支持 KVM?2. 使用 Docker 启动 Windows3. 访问 Docker 启动的 Windows4. Docker Hub 地址5. Github 地址 0. 背景 我们可以在 Windows 系统使用安装 wsl-ubuntu,今天玩玩在 wsl-ub…...

Datawhale 组队学习之大模型理论基础 Task7 分布式训练

第8章 分布式训练 8.1 为什么分布式训练越来越流行 近年来,模型规模越来越大,对硬件(算力、内存)的发展提出要求。因为内存墙的存在,单一设持续提高芯片的集成越来越困难,难以跟上模型扩大的需求。 为了…...

05-使用结构体构建相关数据

上一篇: 04-了解所有权 结构体(struct)是一种自定义数据类型,可以将多个相关值打包命名,组成一个有意义的组。如果你熟悉面向对象的语言,那么结构体就像是对象的数据属性。在本章中,我们将对元组…...

【Android】Android中的系统镜像由什么组成?

文章目录 总览Boot Loader 的加锁与解锁Boot 镜像内核RAM diskARM 中的设备树 (Device Tree) /System 和/Data 分区镜像参考 总览 各种Android设备都只能刷专门为相应型号的设备定制的镜像。 厂商会提供一套系统镜像把它作为“出厂默认”的 Android 系统刷在设备上。 一个完…...

仿真机器人-深度学习CV和激光雷达感知(项目2)day7【ROS关键组件】

文章目录 前言Launch 文件了解 XML 文件Launch 文件作用Launch 文件常用标签实例--作业1的 Launch 文件TF Tree介绍发布坐标变换--海龟例程获取坐标变换--海龟自动跟随例程rqt_工作箱前言 💫你好,我是辰chen,本文旨在准备考研复试或就业 💫本文内容是我为复试准备的第二个…...

解锁一些SQL注入的姿势

昨天课堂上布置了要去看一些sql注入的案例,以下是我的心得: ​​​​​​​ ​​​​​​​ ​​​​​​​ 1.新方法 打了sqli的前十关,我发现一般都是联合查询,但是有没有不是联合查询的方法呢&#xf…...

Qt 拖拽事件示例

一、引子 拖拽这个动作,在桌面应用程序中是非常实用和具有很友好的交互体验的。我们常见的譬如有,将文件拖拽到某个窗口打开,或者拖拽文件到指定位置上传;在绘图软件中,选中某个模板、并拖拽到画布上,画布上变回绘制该模板的图像… 诸如此类,数不胜数。 那么,在Qt中我…...

Linux:命名管道及其实现原理

文章目录 命名管道指令级命名管道代码级命名管道 本篇要引入的内容是命名管道 命名管道 前面的总结中已经搞定了匿名管道,但是匿名管道有一个很严重的问题,它只允许具有血缘关系的进程进行通信,那如果是两个不相关的进程进行通信&#xff0…...

实习记录——第五天

今天我的心情不是很美丽,昨天晚上没怎么睡好,因为我一直在想离不离开实验室?该怎么说的事情?但是又觉得这个项目还没有完全结束,冒昧提这个事情是不是不好?最终也没得出一个结论,晚上睡得也不踏…...

Kotlin 教程(环境搭建)

Kotlin IntelliJ IDEA环境搭建 IntelliJ IDEA 免费的社区版下载地址:Download IntelliJ IDEA – The Leading Java and Kotlin IDE 下载安装后,我们就可以使用该工具来创建项目,创建过程需要选择 SDK, Kotlin 与 JDK 1.6 一起使…...

04.领域驱动设计:了解聚合和聚合根,怎样设计聚合-学习总结

目录 1、概述 2、聚合 3、聚合根 4、怎么设计聚合 4.1 聚合的构建过程主要步骤 第 1 步:采用事件风暴。 第 2 步:选出聚合根。 第 3 步:找出与聚合根关联的所有紧密依赖的实体和值对象。 第 4 步:画出对象的引用和依赖模型…...

cmake-find_package链接第三方库

文章目录 基本调用形式和模块模式使用方式 之前我们是使用了绝对路径来链接OpenCV第三方库,但是现在很多库一般会自己写一些cmake文件提供给用户,用户可以直接使用其中的内置变量即可。使用的命令就是find_package。 基本调用形式和模块模式 find_packa…...

obsidian阅读pdf和文献——与zotero连用

参考: 【基于Obsidian的pdf阅读、标注,构建笔记思维导图,实现笔记标签化、碎片化,便于检索和跳转】 工作流:如何在Obsidian中阅读PDF - Eleven的文章 - 知乎 https://zhuanlan.zhihu.com/p/409627700 操作步骤 基于O…...

走方格(动态规划)

解题思路: 找边界,即行为1,列为1。 拆分问题,拆分成一次走一步,只能向右或者向下走。 解题代码: public static void main(String[] args) {int [][]arrnew int[31][31];Scanner scnew Scanner(Sys…...

基于DataKit迁移MySQL到openGauss

📢📢📢📣📣📣 哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】!😜&am…...

API网关-Apinto压缩包方式自动化安装配置教程

文章目录 前言一、Apinto安装教程1. 复制脚本2. 增加执行权限3. 执行脚本4. Apinto命令4.1 启动Apinto4.2 停止Apinto4.3 重启Apinto4.4 查看Apinto版本信息4.5 加入Apinto集群4.6 离开Apinto集群4.7 查看Apinto节点信息 5. 卸载Apinto 二、Apserver(Apinto Dashboard V3)安装教…...

内网穿透natapp使用教程(Linux)

我的使用场景:在家访问学校服务器,由于不在一个局域网,所以需要使用内网穿透,我使用的是natapp。需要在有局域网的时候做好以下步骤。 (natapp官网:https://natapp.cn/) 1. 下载客户端 &#x…...

别再一个个点菜单了!MathType 7.4.8快捷键保姆级清单,效率翻倍不是梦

MathType 7.4.8快捷键全攻略:从入门到精通的效率革命 在数学公式编辑的世界里,每个操作都像是一场与时间的赛跑。当你在深夜赶论文时,当你在实验室紧急修改报告时,那些隐藏在菜单深处的功能是否让你感到焦躁?MathType作…...

从《致爱丽丝》到《野蜂飞舞》:通过经典钢琴曲片段,手把手教你识别小字组、大字组在五线谱上的位置

从《致爱丽丝》到《野蜂飞舞》:用经典旋律解锁五线谱的密码 第一次翻开钢琴谱时,那些上下翻飞的音符就像天书般令人困惑。为什么同样的音符在不同位置听起来音高差异巨大?为什么低音谱号和高音谱号的"Do"位置完全不同?其…...

紧急预警!YouTube已启动Sora 2生成内容专项识别模型(v2.3.1),你的视频是否在灰度检测池?立即自查清单

更多请点击: https://intelliparadigm.com 第一章:紧急预警!YouTube已启动Sora 2生成内容专项识别模型(v2.3.1),你的视频是否在灰度检测池?立即自查清单 YouTube 已于 2024 年 6 月 18 日凌晨正…...

崩坏星穹铁道模拟宇宙自动化终极指南:如何轻松实现全自动刷图

崩坏星穹铁道模拟宇宙自动化终极指南:如何轻松实现全自动刷图 【免费下载链接】Auto_Simulated_Universe 崩坏:星穹铁道 模拟宇宙自动化 (Honkai Star Rail - Auto Simulated Universe) 项目地址: https://gitcode.com/gh_mirro…...

【Oracle数据库指南】第37篇:Oracle角色与PROFILE管理详解

上一篇【第36篇】Oracle用户与权限管理详解(完整版) 下一篇【第38篇】Oracle数据库备份策略与实现详解 摘要 角色(Role)是权限的命名集合,通过角色可以将多个权限统一管理,简化复杂的权限授予操作&#xf…...

CISP认证报考必看:从考完到出分、查证、续证一文说清

今天,这篇主要关于CISP出成绩、查成绩和有效期的干货,今天结合官方规则和常见情况说清楚,省得大家瞎等。一、CISP是什么?报考条件如何?在深入流程之前,先简单说下CISP的定位。CISP由中国信息安全测评中心&a…...

API中转站接入到知识库问答时,怎么做平台对比

知识库问答是很多团队接入大模型的第一站。 它看起来简单:用户提问,检索文档,把上下文发给模型,再返回答案。但真正上线后,问题会多很多。上下文太长怎么办?模型乱答怎么办?图片和 PDF 怎么处理…...

Cadence 17.4 实战指南:从零到一构建高速PCB设计流程

1. 初识Cadence 17.4:高速PCB设计的起点 第一次打开Cadence 17.4时,那个蓝底白字的启动界面让我想起了刚入行时的场景。作为电子设计自动化(EDA)领域的标杆工具,Cadence Allegro系列一直是高速PCB设计的首选。不同于其…...

XXL-Job任务堆积导致‘结果丢失’?别慌,手把手教你排查与优化(附真实生产案例)

XXL-Job任务堆积导致‘结果丢失’?别慌,手把手教你排查与优化(附真实生产案例) 在分布式任务调度系统中,XXL-Job因其轻量级、易用性而广受欢迎。然而,当系统负载升高或任务执行时间超出预期时,任…...

Bebas Neue字体完全指南:从入门到精通的终极探索之旅

Bebas Neue字体完全指南:从入门到精通的终极探索之旅 【免费下载链接】Bebas-Neue Bebas Neue font 项目地址: https://gitcode.com/gh_mirrors/be/Bebas-Neue 还在为设计项目寻找一款既专业又完全免费的字体而烦恼吗?Bebas Neue作为一款采用SIL …...