element-plus 上传组件 el-upload 直传第一次取不到数据

取不到数据是官方("element-plus": "^2.3.4") beforeData在beforeUploadPromise 之前导致异步设置:data 不生效文件传不上去的原因,改为http-request去处理就可以了。挺奇怪,之前用("element-plus": "^2.2.17")是没有问题的。

在before-upload里请求后端接口获取到accessid、policy、signature、dir等。

在http-request里

javascript 复制代码
const httpRequest: UploadRequestHandler = async (options: UploadRequestOptions) => {
  console.log(options);
  let formdata = new FormData();
  formdata.append("ossaccessKeyId", dataOss.value.ossaccessKeyId);
  formdata.append("policy", dataOss.value.policy);
  formdata.append("signature", dataOss.value.signature);
  formdata.append("host", dataOss.value.host);
  formdata.append("key", dataOss.value.key);
  formdata.append("success_action_status", "200");
  formdata.append("file", options.file);
  uploadFileToOSS(formdata, options.action).then(res => {
    console.log(res);
    if (res.status == 200) {
      options.onSuccess(res);
    } else {
      ElMessage({ message: "上传失败", type: "error", showClose: true });
    }
  });
};


const uploadFileToOSS = (data: any, action: string) => {
  return axios({
    url: action,
    method: "POST",
    data: data,
    headers: {
      "Content-Type": "multipart/form-data"
    }
  });
};
相关推荐
yy.y--1 小时前
Java数组逆序读写文件实战
java·开发语言
CappuccinoRose1 小时前
HTML语法学习文档(五)
前端·html·html5·表单
BD_Marathon2 小时前
IDEA创建多级包时显示在同一行怎么办
java·ide·intellij-idea
亓才孓2 小时前
【Exception】CONDITIONS EVALUATION REPORT条件评估报告
java·开发语言·mybatis
硅基动力AI2 小时前
如何判断一个关键词值不值得做?
java·前端·数据库
重生之后端学习3 小时前
78. 子集
java·数据结构·算法·职场和发展·深度优先
yq1982043011563 小时前
使用Django构建视频解析网站 从Naver视频下载器看Web开发全流程
前端·django·音视频
那起舞的日子3 小时前
斐波那契数列
java·算法
李明卫杭州4 小时前
在 JavaScript 中,生成器函数(Generator Function)
前端·javascript
想用offer打牌4 小时前
一站式了解接口防刷(限流)的基本操作
java·后端·架构