欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue使用axios实现文件上传进度的实时更新详解

程序员文章站 2022-11-29 20:36:41
axios 简介 axios 是一个基于promise 用于浏览器和 nodejs 的 http 客户端,它本身具有以下特征: 从浏览器中创建 xmlhttpr...

axios 简介

axios 是一个基于promise 用于浏览器和 nodejs 的 http 客户端,它本身具有以下特征:

  • 从浏览器中创建 xmlhttprequest
  • 从 node.js 发出 http 请求
  • 支持 promise api
  • 拦截请求和响应
  • 转换请求和响应数据
  • 取消请求
  • 自动转换json数据
  • 客户端支持防止 csrf/xsrf

引入方式:

$ npm install axios
//使用淘宝源
$ cnpm install axios
//或者使用cdn:
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

安装其他插件的时候,可以直接在 main.js 中引入并使用 vue.use()来注册,但是 axios并不是vue插件,所以不能 使用vue.use() ,所以只能在每个需要发送请求的组件中即时引入。

为了解决这个问题,我们在引入 axios 之后,通过修改原型链,来更方便的使用。

//main.js

import axios from 'axios'
vue.prototype.$http = axios

在 main.js 中添加了这两行代码之后,就能直接在组件的 methods 中使用 $http命令

methods: {
postdata () {
this.$http({
method: 'post',
url: '/user',
data: {
name: 'xiaoming',
info: '12'
}
})
}

更多的基础知识大家可以参考这篇文章:

vue使用axios实现文件上传进度实时更新

xhr二级增加了progress事件,我们可以据此在浏览器接收新数据期间添加实时数据进度条,从而使得交互更加友好

vue模板

<div class="progress" @click="upload"
   :style="{backgroundimage:'linear-gradient(to right,#c0c7cb 0%,#c0c7cb '+progress+',#e1e6e9 '+progress+',#e1e6e9 100%)'}">

vue-js

 var form = new formdata()
 form.append('file', vm.$refs.upload.files[0])
 form.append('id', id)
 form.append('type', type)
 var config = {
  onuploadprogress: progressevent => {
   var complete = (progressevent.loaded / progressevent.total * 100 | 0) + '%'
   this.progress = complete
  }
 }
 axios.post(`api/uploadfile`,
  form, config).then((res) => {
  if (res.data.status === 'success') {
   console.log('上传成功')
  }
 })

关键点在于progress事件,而axios对ajax封装之后需要在axios的config参数里面写好事件处理函数(具体参数写法可查看axios文档)

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。