fetch 封装 文件流下载进度监控-demo

要使用 fetch API 下载文件并监控下载进度,你需要处理响应的 ReadableStream。这里是一个如何封装此功能的基本示例:

<script setup lang="ts">
const downloadFileWithProgress = async (url, onProgress) => {// 发起 fetch 请求const response = await fetch(url);if (!response.ok) {throw new Error(`HTTP error! status: ${response.status}`);}const reader = response.body.getReader();const contentLength = +response.headers.get('Content-Length');let receivedLength = 0; // 接收到的字节数let chunks = []; // 用于存储二进制块的数组// 读取数据while (true) {const { done, value } = await reader.read();if (done) {break;}chunks.push(value);receivedLength += value.length;// 调用 onProgress 回调函数if (onProgress) {onProgress(receivedLength / contentLength);}}// 将所有块合并成一个 Uint8Arraylet chunksAll = new Uint8Array(receivedLength);let position = 0;for (let chunk of chunks) {chunksAll.set(chunk, position);position += chunk.length;}// 创建一个 Blob 并返回 URLconst blob = new Blob([chunksAll]);const downloadUrl = URL.createObjectURL(blob);return downloadUrl;
};// 这个例子中的 onProgress 函数只是打印出下载进度
const onProgress = (progress) => {console.log(`Downloaded ${Math.round(progress * 100)}%`);
};// 调用封装的函数
const downloadUrl = 'https://example.com/file'; // 设置你的文件 URLconst startDownload = async () => {try {const url = await downloadFileWithProgress(downloadUrl, onProgress);// 创建一个a标签来触发下载const a = document.createElement('a');a.href = url;a.download = 'file_name.ext'; // 设置下载文件的名称document.body.appendChild(a);a.click();document.body.removeChild(a);URL.revokeObjectURL(url);} catch (error) {console.error('Download failed:', error);}
};
</script><template><button @click="startDownload">Download File</button>
</template>

在这个示例中,downloadFileWithProgress 函数接受一个文件 URL 和一个进度回调函数。使用 fetch 请求文件,然后通过读取 ReadableStream 来处理文件流。当读取到新的数据块时,进度回调会被调用,更新下载进度。读取完成后,它将所有数据块合并到一个 Uint8Array 中,然后创建一个 Blob,最终生成一个可以下载的 URL。

请注意,进度监控假设服务器发送了正确的 Content-Length 头。如果没有这个头,或者它的值不正确,那么进度指示将无法工作。

在实际应用中,确保处理各种可能的异常情况,并提供用户反馈。此外,由于 CORS 策略,你可能无法从其他域获取 Content-Length 头,除非其他域的服务器设置了适当的 CORS 头来允许这样做。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/33102.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

北斗三号短报文通信终端 | 助力户外无网络场景作业

北斗三号短报文通信终端是一款专为户外无网络场景作业设计的先进通信工具&#xff0c;它依托于中国自主研发的北斗卫星导航系统&#xff0c;为用户在偏远地区或无网络覆盖区域提供了可靠的通信保障。以下是关于北斗三号短报文通信终端的详细介绍&#xff1a; 一、功能特点 北斗…

【Linux系列】tree 命令的实用指南

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

头歌——机器学习——集成学习案例

第1关&#xff1a;基于集成学习模型的应用案例 任务描述 本次任务我们将会使用银行营销数据集&#xff08;来源于UCI数据集&#xff1a;UCI Machine Learning Repository &#xff09;,该数据集共45211条数据&#xff0c;涉及葡萄牙银行机构的营销活动&#xff0c;通过一些与…

大端和小端存储

在计算机科学中&#xff0c;数据存储的“字节顺序”是指数据的字节在内存中排列的顺序。主要有两种字节序&#xff1a;大端&#xff08;Big Endian&#xff09;和小端&#xff08;Little Endian&#xff09;。 大端字节序 (Big Endian) 大端字节序将数据的高位字节存储在内存…

【机器学习】自然语言处理的新前沿:GPT-4与Beyond

&#x1f4dd;个人主页&#xff1a;哈__ 期待您的关注 目录 &#x1f525;引言 背景介绍 文章目的 一、GPT-4简介 GPT-4概述 主要特性 局限性和挑战 二、自监督学习的新进展 自监督学习的原理 代表性模型和技术 三、少样本学习和零样本学习 少样本学习的挑战 先…

Maven深度解析:Java项目构建

Maven是一个由Apache软件基金会维护的软件项目管理和理解工具&#xff0c;它主要服务于基于Java的软件项目。。 Maven深度解析&#xff1a;Java项目构建 引言 在Java开发领域&#xff0c;项目构建和管理是一个复杂而关键的任务。Maven作为这一领域的佼佼者&#xff0c;以其声…

【MDK5问题】:MDK5无法跳转,并且提示:no browse information available in xxxxx

1、问题&#xff1a; MDK5原来的函数调用可以直接跳转到原函数&#xff0c;但是出现不能跳转原函数的情况&#xff0c;且提示&#xff1a;no browse information available in xxxxx 的情况&#xff1b; 2、解决&#xff1a; 如下图所示&#xff1a;在魔术棒&#xff08;pro…

使用 JavaScript 获取电池状态

在现代的移动设备和笔记本电脑上&#xff0c;了解电池状态是一项非常有用的功能。使用 JavaScript 可以轻松地获取电池的充电状态、电量百分比等信息。本文将介绍如何使用 JavaScript 访问这些信息&#xff0c;并将其显示在网页上。 1. HTML 结构 首先&#xff0c;我们需要一…

【React Native】measureInWindow在安卓上无法正确获取View在屏幕上的布局信息

问题描述&#xff1a; 在React Native中&#xff0c;我们可以使用measureInWindow的方式去获取一个View在屏幕中的位置信息&#xff1a; 下面这个Demo中&#xff0c;我们写了一个页面HomePage和一个列表项组件ListItemA&#xff0c;我们期望每过5s监测一次列表中每一项在屏幕中…

FW Activity跳转动画源码解析(一)

文章目录 跳转动画实际操作的是什么?窗口怎么知道应该执行什么动画,是透明,还是平移,还是缩放,旋转? 跳转动画实际操作的是什么? startActivity调用之后进行页面跳转,会有一系列的涉及到ActivitStar,ActivityTask,ActivityManager等类的操作,最终在执行动画会调用到Surface…

【LinuxC语言】第一个简单的tcp/ip客户端

文章目录 前言一、客户端连接服务器的示意图二、客户端涉及的相关函数socket函数connect函数struct sockaddr结构体相关的转换函数connect主体函数发送数据函数接收数据函数关闭socket客户端示例代码总结前言 在计算机网络中,TCP/IP 是最常见的网络协议。它为我们提供了一种可…

可视化实训复习篇章

前言&#xff1a; 今天&#xff0c;我们来学习seaborn库可视化&#xff0c;当然&#xff0c;这个建立在Matplotlib的基础上&#xff0c;话不多说&#xff0c;进入今天的正题吧&#xff01;当然&#xff0c;这个是《python数据分析与应用》书中&#xff0c;大家有需求的可以参考…

将一维机械振动信号构造为训练集和测试集(Python)

从如下链接中下载轴承数据集。 https://www.sciencedirect.com/science/article/pii/S2352340918314124 import numpy as np import scipy.io as sio import matplotlib.pyplot as plt import statistics as stats import pandas as pd from sklearn.model_selection import t…

在Ubuntu下将pulseaudio换成pipewire

1、为什么要将pulseaudio换成pipewire&#xff1f; PulseAudio 是一个成熟且广泛使用的音频服务器&#xff0c;适合一般桌面音频需求&#xff0c;但在性能和延迟上有一定限制。PipeWire 是一个更现代的解决方案&#xff0c;旨在统一音频和视频处理&#xff0c;提供高性能和低延…

苹果可能与 Meta 合作开发人工智能

随着苹果进入AI领域&#xff0c;它也在寻求合作伙伴的帮助。 在本月早些时候宣布Apple Intelligence期间&#xff0c;苹果表示将与OpenAI合作&#xff0c;将ChatGPT引入改版后的Siri。据《华尔街日报》报道&#xff0c;苹果和Facebook的母公司Meta也在讨论类似的合作事宜。 据…

微服务、多租户、单点登录、国产化形成的开源Java框架!

一、项目简介 JVS是软开企服构建的一站式数字化的开源框架&#xff0c;支持对接多种账户体系&#xff0c;支持多租户、支持Auth2、统一登录、单点登录等&#xff0c;支持原生开发、低代码/零代码开发应用。 二、框架核心功能 控制台(首页)&#xff1a;采用配置化的方式 用户…

已经被驳回的商标名称还可以申请不!

看到有网友在问&#xff0c;已经驳回的商标名称还可以申请不&#xff0c;普推商标知产老杨觉得要分析看情况&#xff0c;可以适当分析下看可不可以能申请&#xff0c;当然最终还是为了下证 &#xff0c;下证概率低的不建议申请。 先看驳回理由&#xff0c;如果商标驳回是绝对理…

华为某员工爆料:偷偷跑出去面试,被面试官鄙视了。第一句话就问:华为淘汰的吧,35岁了,这个年龄在华为能混得下去吗?身体没啥毛病吧

“你都35岁了&#xff0c;难不成是被华为淘汰的&#xff1f;在华为混不下去了吧&#xff1f;身体没啥毛病吧&#xff0c;我们这体检可是很严的。” 近日&#xff0c;一位华为员工在朋友圈爆料&#xff0c;自己在面试时遭到了面试官的无理取闹和人身攻击&#xff0c;原因仅仅是因…

RK3568 Android 11,安装apk有哪些方法

在RK3568 Android 11设备上安装APK文件&#xff0c;您可以使用以下几种方法&#xff1a; 1. 通过文件管理器安装 将APK文件传输到设备上&#xff0c;可以通过USB连接、蓝牙、电子邮件附件等方式。打开设备上的文件管理器应用。导航到APK文件所在的目录。点击APK文件&#xff…

【Java】内部类

认识内部类&#xff1a;Java中内部类分如下三种 匿名内部类 实例内部类 静态实例内部类 匿名内部类 匿名内部类顾名思义就是在创建的时候不用赋予名字。 代码演示&#xff1a; //匿名内部类 interface IA{void test(); } public class Main{public static void main(Str…