【js】监听文件上传下载进度,设置请求头信息与获取响应头信息

监听文件上传下载进度

例子:html部分

<input type="file" id="selectFile">
<span id="progress1"></span><button id="downloadFile">download</button>
<span id="progress2"></span>

原生xhr实现

const selectFile = document.querySelector('#selectFile')
const progress1 = document.querySelector('#progress1')const downloadFile = document.querySelector('#downloadFile')
const progress2 = document.querySelector('#progress2')selectFile.addEventListener('change', e => {const file = e.target.files[0]const xhr = new XMLHttpRequest()// 跟踪上传进度xhr.upload.onprogress = function(event) {const percent = Math.floor((event.loaded / event.total) * 100)progress1.innerHTML = percent + '%'console.log(`Uploaded ${event.loaded} of ${event.total}, ${percent}%`)}// 跟踪完成:无论成功与否xhr.onloadend = function() {if (xhr.status == 200) {console.log("success")} else {console.log("error " + this.status)}}xhr.open("POST", "upload.php")xhr.send(file)
})downloadFile.addEventListener('click', e => {const xhr = new XMLHttpRequest()xhr.onprogress = function(event) {if (event.lengthComputable) {const percent = Math.floor((event.loaded / event.total) * 100)progress2.innerHTML = percent + '%'console.log(`Received ${event.loaded} of ${event.total} bytes`)} else {console.log(`Received ${event.loaded} bytes`) // 没有 Content-Length}}// 跟踪完成:无论成功与否xhr.onloadend = function() {if (xhr.status == 200) {console.log("success")} else {console.log("error " + this.status)}}xhr.open("GET", "imgs/demo.mp4")xhr.send()
})

使用axios库

const selectFile = document.querySelector('#selectFile')
const progress1 = document.querySelector('#progress1')const downloadFile = document.querySelector('#downloadFile')
const progress2 = document.querySelector('#progress2')
selectFile.addEventListener('change', e => {const file = e.target.files[0]axios({url: 'upload.php',method: 'post',data: file,onUploadProgress: event => {// axios已经对progress进行了封装,可以直接获取计算好的值// const percent = Math.floor((event.loaded / event.total) * 100)const percent = Math.floor(event.progress * 100)progress1.innerHTML = percent + '%'console.log(`Uploaded ${event.loaded} of ${event.total}, ${percent}%`)}}).then(res => {const body = res.dataconsole.log(body)})
})downloadFile.addEventListener('click', e => {axios({url: 'imgs/demo.mp4',method: 'get',onDownloadProgress: event => {// axios已经对progress进行了封装,可以直接获取计算好的值// const percent = Math.floor((event.loaded / event.total) * 100)const percent = Math.floor(event.progress * 100)progress2.innerHTML = percent + '%'console.log(`Received ${event.loaded} of ${event.total} bytes`)}}).then(res => {console.log('success')})
})

设置请求头信息与获取响应头信息

原生xhr实现

const xhr = new XMLHttpRequest()// 跟踪上传进度
xhr.upload.onprogress = function(event) {console.log('progress:', event)const percent = Math.floor((event.loaded / event.total) * 100)progress1.innerHTML = percent + '%'console.log(`Uploaded ${event.loaded} of ${event.total}, ${percent}%`)
}// 跟踪完成:无论成功与否
xhr.onloadend = function() {if (xhr.status == 200) {// 此处获取服务端额外返回的响应header,名字叫X-My-Custom-Headerconst serverExtraHeader = xhr.getResponseHeader('X-My-Custom-Header')// 获取服务器返回的响应Date字段(一般apache和nginx都能返回的服务器时间)const serverDate = xhr.getResponseHeader('Date')const handlerDate = new Date(serverDate)console.log("success:", handlerDate, serverExtraHeader)} else {console.log("error " + this.status)}
}xhr.open("POST", "upload.php")
// 设置更多的请求header,必须放在open之后
xhr.setRequestHeader('extra-header', 'extra-header-value')
xhr.send(file)

使用axios库

axios({url: 'upload.php',method: 'post',data: file,// 设置更多的请求headerheader: {'extra-header': 'extra-header-value'},onUploadProgress: event => {console.log('event:', event)// const percent = Math.floor((event.loaded / event.total) * 100)const percent = Math.floor(event.progress * 100)progress1.innerHTML = percent + '%'console.log(`Uploaded ${event.loaded} of ${event.total}, ${percent}%`)}
}).then(res => {const body = res.data// 获取服务端/服务器返回的响应header,注意:由于axios进行了封装,所有header的key都变成了小写const headers = res.headersconst serverExtraHeader = headers['x-my-custom-header']const serverDate = headers['date']console.log(body, serverExtraHeader, serverDate)
})

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

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

相关文章

关联对象介绍

关联对象的作用 在分类里面&#xff0c;不可以直接为分类添加属性 在代理中&#xff0c;不可以直接为代理添加属性 在普通类中&#xff0c;property (assign, nonatomic) int age; 会做三件事&#xff1a; 生成age的成员变量生成age的get、set方法的声明生成age的get、set方…

使用 Docker 部署 Puter 云桌面系统

1&#xff09;Puter 介绍 :::info GitHub&#xff1a;https://github.com/HeyPuter/puter ::: Puter 是一个先进的开源桌面环境&#xff0c;运行在浏览器中&#xff0c;旨在具备丰富的功能、异常快速和高度可扩展性。它可以用于构建远程桌面环境&#xff0c;也可以作为云存储服…

Unix运维_如何测试C11和C++11至C17和C++17标准的支持

Unix运维_如何测试C11和C11至C17和C17标准的支持 C语言 标准主要有以下几个版本: K&R C: 这是 C语言 的第一个标准, 由 Dennis Ritchie 和 Brian Kernighan 于 1978 年在《The C Programming Language》一书中定义。K&R C 标准包含了基本的语法, 数据类型, 运算符等,…

C# OpenFileDialog

c#—OpenFileDialog&#xff08;打开文件对话框&#xff09; OpenFileDialog 是 Windows Forms 应用程序中用于打开文件的常用对话框。它提供了一个标准的用户界面&#xff0c;让用户能够浏览文件夹、查看文件列表以及选择一个或多个文件。下面是一个使用 OpenFileDialog 的基本…

codeforces Edu 142 D. Fixed Prefix Permutations 【思维、字典树求LCP】

D. Fixed Prefix Permutations 题意 给定 n n n 个长度为 m m m 的排列 a 1 , a 2 , . . . a n a_1,a_2,...a_n a1​,a2​,...an​ 定义一个排列 p p p 的 价值 为 最大顺序长度 k k k&#xff1a; p 1 1 , p 2 2 , p 3 3 , . . . p k k p_1 1,p_2 2, p_3 3, ...…

在编程中使用中文到底该不该??

看到知乎上有个热门问题&#xff0c;为什么很多人反对中文在编程中的使用&#xff1f; 这个问题有几百万的浏览热度&#xff0c;其中排名第一的回答非常简洁&#xff0c;我深以为然&#xff1a; 在国内做开发&#xff0c;用中文写注释、写文档&#xff0c;是非常好的习惯&…

产品经理功法修炼(2)之专业技能

点击下载《产品经理功法修炼(2)之专业技能》 1. 前言 产品经理的能力修炼并非局限于某一技能的速成,而是需要全面参与到产品的整个生命周期中,通过不断的实践来逐步提升自己的各项能力。尽管在企业的日常运作中,我们不可能身兼数职去扮演每一个角色,但作为产品的核心负…

【适用于福彩3D和体彩排列3】012路直选代码对照表

在我的第6套算法中&#xff0c;我用自己搭建的AI模型&#xff0c;对012路直选进行了预测&#xff0c;但是由于没有对照表&#xff0c;导致很多朋友无法看懂预测结果。众所周知&#xff0c;对于012路直选&#xff0c;共计27种组合方式。我自己进行了组合分类&#xff0c;并赋予相…

建立mysql测试数据

建立一个多数据&#xff0c;多字段的大表&#xff0c;索引有意不全&#xff0c;用于多线程测试 1.建表 /*Navicat Premium Data TransferSource Server : duoSource Server Type : MySQLSource Server Version : 80300 (8.3.0)Source Host : localhost:…

LeetCode 209 长度最小的子数组(滑动窗口,双指针实现)

给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续 子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度。如果不存在符合条件的子数组&#xff0c;返回 0 。 示例 1&#xff1a; 输入&…

微知识-git rebase常用的3个场景和2个本质

如何修改历史提交的commit 的msg信息 r &#xff0d; git rebase -i xxxx 其中xxx是需要修改的commit的father , -i 是指交互式 &#xff0d; 将pick 修改为r 表示修改commit msg &#xff0d; 其他的不要动 git rebase的原理是&#xff0c;在交互式界面好比是输入命令&#x…

[C/C++] -- 二叉树

1.简介 二叉树是一种每个节点最多有两个子节点的树结构&#xff0c;通常包括&#xff1a;根节点、左子树、右子树。 满二叉树&#xff1a; 如果一棵二叉树只有度为0的结点和度为2的结点&#xff0c;并且度为0的结点在同一层上&#xff0c;则这棵二叉树为满二叉树。深度为k&a…

创研杯赛事:激发英语热情,助力人才培养

2024 中国翻译协会年会期间&#xff0c;知名赛事活动平台赛氪承办的“AI 科技时代竞赛与就业”分论坛&#xff0c;于 3 月 30 日下午在长沙圆满落幕。其中值得瞩目的是&#xff0c;第三届”创研杯“大赛也在本次会议上进行了启动。 创研杯赛事由空中英语教室杂志社发起主办&am…

【解决问题】排查linux文件手动删除文件,但是文件标记为deleted,资源未释放

背景&#xff1a; 生产环境我们把程序生成的数据文件手动删除后&#xff0c;但是空间并没有释放&#xff0c;导致硬盘被占用&#xff0c;不够用 问题排查&#xff1a; 1.查看占用文件状态 使用命令&#xff1a; lsof | grep deleted 查看 文件已经删除了&#xff0c;但是都是…

Oracle学习之路:从小白到专家

一、引言 A. 博客文章的目的和背景 本博客的目的是为那些想要学习Oracle数据库的人提供一个初步的指南&#xff0c;帮助他们从小白到专家的过程。Oracle是一种广泛使用的关系型数据库管理系统&#xff0c;具有广泛的应用场景&#xff0c;因此深入学习Oracle是一个有意义的投资…

C语言 | Leetcode C语言题解之第5题最长回文子串

题目&#xff1a; 题解&#xff1a; char* longestPalindrome(char* s) {int lenstrlen(s),max0;int p0;for(int i0;i<len;i)//这种是判断奇数回文{int lefti-1,righti1;//left左边&#xff0c;right右边while(left>0&&right<len&&s[left]s[right]){/…

自定义多阶段倒计时实现分段倒计时

直接贴代码好了 情况是这么个情况 老板想要一个倒计时完毕后再接下一个倒计时总共四五个算一轮业务结束的这个样子 然后循环执行这个业务,这些循环执行我就用了xxl-job ,整体业务就用信号量执行了,总的来说是返回给前端的时间是零误差的, 业务处理的都用异步去执行保证时间总的…

【JavaScript】使用 NVM 管理 Node.js 版本

风决定要走 云怎么挽留 曾经抵死纠缠放空的手 情缘似流水覆水总难收 我还站在你离开 离开的路口 你既然无心 我也该放手 何必痴痴傻傻纠缠不休 是情深缘浅 留一生遗憾 还是情浅缘深 一辈子怨偶 &#x1f3b5; 庄心妍《以后的以后》 Node.js 是一个广泛使用…

10.图像高斯滤波的原理与FPGA实现思路

1.概念 高斯分布 图像滤波之高斯滤波介绍 图像处理算法|高斯滤波   高斯滤波(Gaussian filter)包含很多种&#xff0c;包括低通、高通、带通等&#xff0c;在图像上说的高斯滤波通常是指的高斯模糊(Gaussian Blur)&#xff0c;是一种高斯低通滤波。通常这个算法也可以用来模…

FME学习之旅---day19

我们付出一些成本&#xff0c;时间的或者其他&#xff0c;最终总能收获一些什么。 如何使用 Esri 模板地理数据库 在学习之初&#xff0c;首先了解什么是Esri模板、如何使用Esri模板以及如何创建Esri模板 有两种类型的 Esri 模板&#xff1a;文件地理数据库 &#xff08;.gd…