news 2026/2/10 5:56:40

前端文件流下载,零基础入门到精通,收藏这篇就够了

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端文件流下载,零基础入门到精通,收藏这篇就够了

项目中前端下载一般分为两种情况:

  1. 后端直接提供一个文件地址,通过浏览器打开就可以下载。
  2. 需要发送请求,后端返回二进制流数据,前端解析流数据,生成URL实现下载。

前端对应的实质是a标签和Blob文件下载,这两者的区别:

  1. a标签:txt、png、jpg、gif等文件,是不提供直接下载,有兼容性问题,特别是IE。
  2. blob:利用Blob对象可以将文件流转化成Blob二进制对象。该对象兼容性良好,适用于需要动态生成或处理非同源文件的情况。‌通过URL.createObjectURL()方法将Blob对象转换为一个临时的URL下载。

blob对象

Blob对象表示一个不可变、原始数据的类文件对象。它的数据可以按文本或二进制的格式进行读取,也可以转换成ReadableStream来用于数据操作。Blob对象是html5新增的对象,它的作用是用来存储二进制数据的,比如图片、视频、音频等,

属性

const blob = new Blob([], { type: '' });

URL.createObjectURL

URL.createObjectURL()静态方法会创建一个DOMString,其中包含一个表示参数中给出的对象的URL。这个URL的生命周期和创建它的窗口中的document绑定。这个新的URL对象表示指定的File对象或Blob对象。
当我们的document被销毁后,这个URL就会失效,所以我们需要在合适的时机销毁它。

简单说这个方法用来创建一个url的,它的作用是把一个blob对象转换成一个url,这个url可以用来下载文件,也可以用来预览文件。

// 创建下载的链接 const url = URL.createObjectURL(blob); // 释放掉blob对象 URL.revokeObjectURL(url);

传统a标签下载

const a = document.createElement('a'); // 创建a标签 a.style = 'display: none'; a.download = filename''; // 设置下载文件名 a.href = url; // 设置下载地址 document.body.appendChild(a); a.click(); // 触发a标签的click事件 document.body.removeChild(a);

这种方式无法解决浏览器可识别文件直接打开的问题,但是 HTML5 新属性 download 属性会解决这个问题。

a标签 + download属性

URL是同源(同域名、同协议、同端口号)时,这种情况用 a标签加download属性的方式即可,download属性指示浏览器该下载而不是打开该文件,同时该属性值即下载时的文件名;

<a href="path/to/file.jpg" download='file.jpg'>点击下载图片</a>
const a = document.createElement('a'); // 创建a标签 const e = document.createEvent('MouseEvents'); // 创建鼠标事件对象 e.initEvent('click', false, false); // 初始化事件对象 a.href = url; // 设置下载地址 a.download = filename || ''; // 设置下载文件名 a.dispatchEvent(e);

因为a标签下载只能下载同源的文件,如果是跨域的文件,这里包括图片、音视频等媒体文件,都是预览,也无法下载

fetch发送请求

  1. 通过原生fetch请求,动态生成一个a标签实现文件下载。
  2. res.blob()该方法是Fetch API的response对象方法,该方法将后端返回的文件流转换为返回blob的Promise;blob(Binary Large Object)是一个二进制类型的对象,记录了原始数据信息。
  3. URL.createObjectURL(blob)该方法的返回值可以理解为一个指向传入参数对象的url可以通过该url访问参数传入的对象。
// 将url转成blob地址 fetch(url) .then(res => res.blob()) .then(blob => { const a = document.createElement('a'); // 将链接地址字符内容转变成blob地址 a.href = URL.createObjectURL(blob); a.download = filename; // 下载文件的名字 document.body.appendChild(a); a.click(); // 下载完成后 清除占用的缓存资源 window.URL.revokeObjectURL(a.href); document.body.removeChild(a); });

XMLHttpRequest

XMLHttpRequest(‌简称XHR)‌是一个用于创建服务器之间通信的Web API。‌在下载文件时,‌可以通过设置responseTypeblob来接收二进制数据。‌这种方法适用于需要从服务器获取文件流并进行下载的场景。‌与Blob类似,‌XHR也可以用于动态生成文件并触发下载,‌但它在处理异步请求和数据传输方面提供了更多的灵活性。‌

  1. 可通过xhr.setRequestHeader设置请求头参数。
  2. 可通过xhr.getResponseHeader(‘content-disposition’)获取头部参数。
let xhr = new XMLHttpRequest(); // GET请求,downloadURL请求路径url,async(是否异步) xhr.open('GET', downloadURL, true); // 设置请求头参数的方式,如果没有可忽略此行代码 xhr.setRequestHeader("Token", 'Bearer ' + getStorage().token); // token // 设置响应类型为 blob xhr.responseType = 'blob'; // 关键部分 xhr.onload = function () { //如果请求执行成功 if (this.status === 200) { // 下载文件 const blob = new Blob(this.response); const href = window.URL.createObjectURL(blob); // 创建下载的链接 const a = document.createElement('a'); a.href = href; a.download = fileName; // 下载文件名 document.body.appendChild(a); a.click(); // 点击下载 document.body.removeChild(a); // 下载完成移除元素 window.URL.revokeObjectURL(href); // 释放掉blob对象 // 可通过xhr.getResponseHeader('content-disposition')头部参数,文件名等 // let headerParams = xhr.getResponseHeader('content-disposition')?.split(";") || []; } }; // 发送请求 xhr.send(); xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { // 成功后操作 } };

axios请求方式

axios({ method: method ||'post', url, responseType: 'blob', headers: { 'Content-Type': 'application/json; charset=utf-8' // 可在此处添加请求参数 token: 'token值' } data: JSON.stringify(params) }).then(res => { if (res) { const blob = new Blob(res); const url = window.URL.createObjectURL(blob) const a = document.createElement('a') a.style.display = 'none' a.href = href; a.download = fileName; // 下载文件名 document.body.appendChild(link) link.click() document.body.removeChild(link); // 下载完成移除元素 window.URL.revokeObjectURL(url); // 释放掉blob对象 } else { message.error('下载失败') return; } })

无论是通过fetchXMLHttpRequestaxios请求,处理逻辑都是请求成功后,拿到相应的response,这个response就是我们要下载的内容,通过将它转成blob对象,通过URL.createObjectURL创建下载URL,通过a标签实现下载。

2025开年,AI技术打得火热,正在改变前端人的职业命运:

阿里云核心业务全部接入Agent体系;

字节跳动30%前端岗位要求大模型开发能力;

腾讯、京东、百度开放招聘技术岗,80%与AI相关……

大模型正在重构技术开发范式,传统CRUD开发模式正在被AI原生应用取代!

最残忍的是,业务面临转型,领导要求用RAG优化知识库检索,你不会;带AI团队,微调大模型要准备多少数据,你不懂;想转型大模型应用开发工程师等相关岗,没项目实操经验……这不是技术焦虑,而是职业生存危机!

曾经React、Vue等热门的开发框架,已不再是就业的金钥匙。如果认为会调用API就是懂大模型、能进行二次开发,那就大错特错了。制造、医疗、金融等各行业都在加速AI应用落地,未来企业更看重能用AI大模型技术重构业务流的技术人。

如今技术圈降薪裁员频频爆发,传统岗位大批缩水,相反AI相关技术岗疯狂扩招,薪资逆势上涨150%,大厂老板们甚至开出70-100W年薪,挖掘AI大模型人才!

不出1年 “有AI项目开发经验”或将成为前端人投递简历的门槛。

风口之下,与其像“温水煮青蛙”一样坐等被行业淘汰,不如先人一步,掌握AI大模型原理+应用技术+项目实操经验,“顺风”翻盘!

大模型目前在人工智能领域可以说正处于一种“炙手可热”的状态,吸引了很多人的关注和兴趣,也有很多新人小白想要学习入门大模型,那么,如何入门大模型呢?

下面给大家分享一份2025最新版的大模型学习路线,帮助新人小白更系统、更快速的学习大模型!

2025最新版CSDN大礼包:《AGI大模型学习资源包》免费分享**

一、2025最新大模型学习路线

一个明确的学习路线可以帮助新人了解从哪里开始,按照什么顺序学习,以及需要掌握哪些知识点。大模型领域涉及的知识点非常广泛,没有明确的学习路线可能会导致新人感到迷茫,不知道应该专注于哪些内容。

我们把学习路线分成L1到L4四个阶段,一步步带你从入门到进阶,从理论到实战。

L1级别:AI大模型时代的华丽登场

L1阶段:我们会去了解大模型的基础知识,以及大模型在各个行业的应用和分析;学习理解大模型的核心原理,关键技术,以及大模型应用场景;通过理论原理结合多个项目实战,从提示工程基础到提示工程进阶,掌握Prompt提示工程。

L2级别:AI大模型RAG应用开发工程

L2阶段是我们的AI大模型RAG应用开发工程,我们会去学习RAG检索增强生成:包括Naive RAG、Advanced-RAG以及RAG性能评估,还有GraphRAG在内的多个RAG热门项目的分析。

L3级别:大模型Agent应用架构进阶实践

L3阶段:大模型Agent应用架构进阶实现,我们会去学习LangChain、 LIamaIndex框架,也会学习到AutoGPT、 MetaGPT等多Agent系统,打造我们自己的Agent智能体;同时还可以学习到包括Coze、Dify在内的可视化工具的使用。

L4级别:大模型微调与私有化部署

L4阶段:大模型的微调和私有化部署,我们会更加深入的探讨Transformer架构,学习大模型的微调技术,利用DeepSpeed、Lamam Factory等工具快速进行模型微调;并通过Ollama、vLLM等推理部署框架,实现模型的快速部署。

整个大模型学习路线L1主要是对大模型的理论基础、生态以及提示词他的一个学习掌握;而L3 L4更多的是通过项目实战来掌握大模型的应用开发,针对以上大模型的学习路线我们也整理了对应的学习视频教程,和配套的学习资料。

二、大模型经典PDF书籍

书籍和学习文档资料是学习大模型过程中必不可少的,我们精选了一系列深入探讨大模型技术的书籍和学习文档,它们由领域内的顶尖专家撰写,内容全面、深入、详尽,为你学习大模型提供坚实的理论基础(书籍含电子版PDF)

三、大模型视频教程

对于很多自学或者没有基础的同学来说,书籍这些纯文字类的学习教材会觉得比较晦涩难以理解,因此,我们提供了丰富的大模型视频教程,以动态、形象的方式展示技术概念,帮助你更快、更轻松地掌握核心知识

四、大模型项目实战

学以致用,当你的理论知识积累到一定程度,就需要通过项目实战,在实际操作中检验和巩固你所学到的知识,同时为你找工作和职业发展打下坚实的基础。

五、大模型面试题

面试不仅是技术的较量,更需要充分的准备。

在你已经掌握了大模型技术之后,就需要开始准备面试,我们将提供精心整理的大模型面试题库,涵盖当前面试中可能遇到的各种技术问题,让你在面试中游刃有余。


因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

2025最新版CSDN大礼包:《AGI大模型学习资源包》免费分享

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/8 8:54:04

零经验想跳槽转行网络安全,需要准备什么?(详细版)

前言 最近在后台收到了部分私信&#xff0c;大部分都是关于网络安全转行的问题&#xff0c;其中&#xff0c;目前咨询最多的是&#xff1a;觉得现在的工作没有发展空间&#xff0c;替代性强&#xff0c;工资低&#xff0c;想跳槽转行网络安全。其中&#xff0c;大家主要关心的…

作者头像 李华
网站建设 2026/2/6 22:47:35

Open-AutoGLM数字人协同落地难题:3个月实现医院场景规模化部署的秘密

第一章&#xff1a;Open-AutoGLM医疗数字人协同的演进与定位随着人工智能在医疗健康领域的深度渗透&#xff0c;Open-AutoGLM作为新一代开源多模态大模型框架&#xff0c;正推动医疗数字人从单向问答向智能协同诊疗演进。该系统融合自然语言理解、医学知识图谱与临床决策支持能…

作者头像 李华
网站建设 2026/2/2 3:09:31

AI内容生成革命来了,你还在手动写文案?

第一章&#xff1a;AI内容生成革命来了&#xff0c;你还在手动写文案&#xff1f; 人工智能正以前所未有的速度重塑内容创作的生态。从社交媒体文案到技术文档撰写&#xff0c;AI驱动的内容生成工具已经能够以极高的效率输出高质量文本&#xff0c;彻底颠覆传统“逐字敲打”的工…

作者头像 李华
网站建设 2026/2/7 11:59:26

探索生命:潜意识的潜力,为何难以激发?

潜意识是一个我们已经熟悉了的词汇&#xff0c;可是你对潜意识的概念有了解吗&#xff1f;一起来看看。潜意识&#xff0c;目前一般是指那些在正常情况下根本不能变为意识的东西&#xff0c;比如&#xff0c;内心深处被压抑而从无意识到的欲望。正是所谓“冰山理论”&#xff1…

作者头像 李华