【框架】上传文件

【框架】上传文件

在这里插入图片描述

思考

一般上传文件的组件,都会让你填写上传的地址,无论是你二次封装,还是使用已有组件,都需要在组件上填写起码1次以上上传文件的接口地址,这样就不利于前端代码的接口统一调用,而且在一段时间或再进行项目修改,容易遗忘。

处理

索性将上传文件的接口和上传的文件的view彻底分开
接口封装内容:【框架】axios封装(接口)
**
接口示例:

export const UploadExcel = ({file,fn}) => {//上传接口
    return API({
        url:'/api/',
        method: 'POST',
        data:file,
      	onUploadProgress:fn,//axios的监听上传进度的回调
        headers:{
            "Content-Type":"multipart/form-data"
        },
    })
}

调用示例:

let Input=document.createElement('input');//js生成接收文件的DOM
Input.type="file";
Input.click()
Input.onchange=(e)=>{
  let formData = new FormData();
  formData.append("file",e.target.files[0]);
  UploadExcel({
    file:formData,
    progress:(e)=>{//进度回调,用来监听文件上传进度
  		//这里控制渲染上传进度的属性
  	}
  }).then(data=>{
    this.$message.success('导入成功!')
    this.GetTableList();
  }).catch(res=>{
    this.$message.error(res.message)
  })
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值