ajax上传附件进度条取消上传

有的项目会使用到附件上传,要求进度条和取消,之前没有使用axios写过,这次刚好碰到了,记录一下;

项目中版本
"axios": "^0.27.2",
使用
import axios from 'axios'
handleUploadAjax() {
   
    // 取消令牌生成器
    const CancelToken = axios.CancelToken;
    // 获取一个令牌对象, 调用source.cancel(),可以取消上传
    const source = CancelToken.source();
    let formdata = handleUploadFormdata({
   fileName: '', fileType: '', file: any});
     axios({
   
        url: 'url',
        headers: {
   
            'Authorization': `Bearer ${
     getUserToken() || ''}`,
            'Content-Type': 'multipart/form-data',
        },
        method: 'post',
        data: formdata,
        cancelToken: source.token,
        onUploadProgress: (event: any) => {
    // axios中自带获取文件上传进度条回调
            let percent = (event.loaded / event.total * 100).toFixed(2);
        }
    }).then((res) => {
   
    }).catch((err) => {
   
    });
}
FormData创建
handleUploadFormdata(params: {
   fileName: '', fileType:'', file: any}){
   
    const formdata: any = new FormData();
    const entries = Object.entries(params);
    for (const [key, value] of entries) {
   
    formdata.append(key, value);
    };
    return formdata;
}

相关推荐

  1. ajax附件进度取消

    2024-01-27 13:28:03       28 阅读
  2. ASP.NET Core中实现文件下载实时进度功能

    2024-01-27 13:28:03       12 阅读
  3. thinkphp8附件获取文件信息

    2024-01-27 13:28:03       17 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-27 13:28:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-27 13:28:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-27 13:28:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-27 13:28:03       20 阅读

热门阅读

  1. 龙年限定微信红包封面,速领~手慢无!

    2024-01-27 13:28:03       33 阅读
  2. leetcode—跳跃游戏—贪心算法

    2024-01-27 13:28:03       37 阅读
  3. 多进程并发服务器与多线程并发服务器

    2024-01-27 13:28:03       30 阅读
  4. react mui textfield marquee 跑马灯效果实现

    2024-01-27 13:28:03       34 阅读
  5. react hooks的useContext

    2024-01-27 13:28:03       35 阅读
  6. torch.empty()造成的内存溢出问题

    2024-01-27 13:28:03       35 阅读