vue项目实现文件上传

vue项目实现文件上传

<div class="inputFile">
  <span class="input-group">
	  <input class="uploadFile com-btn-upload" id="upload_file" name="file" type="file" accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" @change="getFile"/>
	  <button type="button" class="btn btn-primary">上传文件</button>
  </span>
</div>

getFile(event) {
  var file = document.getElementById("upload_file").files[0];
  var formdata1 = new FormData();// 创建form对象
  formdata1.append('excelFile', file);// 通过append向form对象添加数据,可以通过append继续添加数据
   //添加请求头
  let config = {
    headers: {'Content-Type': 'multipart/form-data'}
  };
  axios.post(home + '/systemTrainDataManage/importSystemTrainAndMDBSF', formdata1, config).then(response => {
    if (response.data.code == 200) {
       $dialog.alert("添加成功", "success", 3000);
    } else {
       $dialog.alert(response.data.message, "error", 3000);
    }
	$("#upload_file").val("");
   })
},
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对你的问题,我可以为你提供以下的思路和代码示例: 1. 在前端页面中添加上传文件的表单,可以使用 VUE 中的 el-upload 组件实现。 2. 在后端代码中编写接收上传文件的接口,可以使用 SpringBoot 中的 MultipartFile 类来处理上传文件。 3. 对于多文件上传,前端页面可以使用 el-upload 组件的 multiple 属性,后端接口则可以使用 MultipartFile[] 数组来接收。 下面是一个示例的前端代码: ```vue <template> <el-upload action="/upload" multiple :on-success="handleSuccess" :before-upload="beforeUpload" > <el-button size="small" type="primary">选择文件</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500k</div> </el-upload> </template> <script> export default { methods: { beforeUpload(file) { const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'; const isLt500K = file.size / 1024 < 500; if (!isJPG) { this.$message.error('只能上传jpg/png文件'); } if (!isLt500K) { this.$message.error('上传文件大小不能超过 500KB'); } return isJPG && isLt500K; }, handleSuccess(response) { this.$message.success(`上传成功:${response}`); }, }, }; </script> ``` 其中,el-upload 组件的 action 属性表示上传文件的后端接口地址,multiple 属性表示支持多文件上传。beforeUpload 方法用于在上传前对文件进行校验,handleSuccess 方法则是上传成功后的回调函数。 下面是一个示例的后端代码: ```java @PostMapping("/upload") public String handleFileUpload(@RequestParam("files") MultipartFile[] files) { List<String> fileNames = new ArrayList<>(); for (MultipartFile file : files) { String fileName = StringUtils.cleanPath(file.getOriginalFilename()); fileNames.add(fileName); try { Path path = Paths.get(uploadDir + fileName); Files.copy(file.getInputStream(), path, StandardCopyOption.REPLACE_EXISTING); } catch (IOException e) { e.printStackTrace(); } } return "Uploaded files: " + fileNames; } ``` 其中,@RequestParam("files") MultipartFile[] files 表示接收名为 files 的文件数组,uploadDir 表示文件上传的目录路径。 希望这个代码示例能够对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值