vue3 element-plus 一次上传多个文件

element-plus原先的 el-upload组件只能一个一个的上传文件,现在有一个需求是选择多张文件,一次上传多张,就需要自己来实现

html代码

 <input ref="upload" type="file" id='upload' name="upload" accept=".jpg" multiple="multiple"
               @change="uploadFile" style="display:none;"/>
 <el-button type="primary" @click="selectFiles">上传素材</el-button>

js 代码

const upload = ref(null);
const selectFiles = function () {
  console.log(upload.value.files);
  upload.value.value = "";//每次点击清空上次选择的文件
  upload.value.click();
}
const uploadFile = function (e) {
    //e.target.files也可以获取到文件列表
  console.log(upload.value.files)
  let files = upload.value.files;
  var form = new FormData();
  for (var i = 0; i < files.length; i++) {
    form.append("files", files[i]);
  }
  form.append("name", head_scene_name);
    //axios 上传,headers需要设置headers: {
   //     'Accept': 'Application/json',
   //     'X-Requested-With': 'XMLHttpRequest',
   //     'Content-Type': 'multipart/form-data'
    //  }
}

java代码

@PostMapping({"/uploadfiles"})
    public RestResult uploadFiles(@RequestParam("files") MultipartFile[] files, @RequestParam("name") String name) {
        
    }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值