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

21 篇文章 0 订阅
7 篇文章 0 订阅

监听文件上传下载进度

例子: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.data
    console.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-Header
    const 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,
  // 设置更多的请求header
  header: {
    '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.headers
  const serverExtraHeader = headers['x-my-custom-header']
  const serverDate = headers['date']
  console.log(body, serverExtraHeader, serverDate)
})
  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于 js 原生实现文件上传,一般可以使用 HTML5 新增的 FormData 对象和 XMLHttpRequest 对象的相关方法来实现。具体步骤如下: 1. 在 HTML 中添加一个表单,包含一个 `<input type="file">` 元素: ``` <form id="myForm"> <input type="file" name="myFile"> <input type="submit" value="Upload File"> </form> ``` 2. 在 JS获取表单元素并监听表单的 `submit` 事件: ``` const myForm = document.getElementById('myForm') myForm.addEventListener('submit', (event) => { event.preventDefault() // 阻止表单默认提交行为 const formData = new FormData(myForm) // 创建一个 FormData 实例 const xhr = new XMLHttpRequest() // 创建一个 XMLHttpRequest 实例 // TODO: 设置 xhr 的事件监听器、请求地址、请求方式等 xhr.send(formData) // 发送请求 }) ``` 3. 在 XMLHttpRequest 实例中设置相应的事件监听器,如 `onload`,`onerror`,`onabort` 等,以处理成功和失败的情况并取得响应数据: ``` xhr.onload = function() { if (this.status === 200) { const data = JSON.parse(this.response) // TODO: 处理响应数据,如显示上传成功的信息等 } else { // TODO: 处理非 200 响应码的情况,如显示上传失败的信息等 } } xhr.onerror = function() { // TODO: 处理请求错误的情况,如显示上传失败的信息等 } xhr.onabort = function() { // TODO: 处理请求被取消的情况,如显示上传被取消的信息等 } ``` 以上是一般的简单处理方式,还可以根据具体需求添加一些限制条件,如文件大小、文件类型、上传进度等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值