element plus + el-upload 多文件上传

<template>
	<el-upload
        class="avatar-uploader-excel"
		ref="uploadRef"
		:limit="limitFile"
		accept=".xlsx, .xls"
		action="#"
        :file-list="fileList"
		:disabled="state.upload.isUploading"
        :on-change="onChangeFun"
		:auto-upload="false"
		drag
        :on-exceed="handleExceed"
        multiple>
			<i class="el-icon-upload"></i>
			<div class="el-upload__text">
				将文件拖拽到此处,或
		        <em>点击上传</em>
			</div>
			<div class="el-upload__tip text-center">
				jpg/png files with a size less than 500kb
			</div>
		</el-upload>
		<el-button type="primary" @click="submitFileForm">确定</el-button>
		<el-button @click="handleCloseUpload">取消</el-button>
</template>

<script setup lang="ts">
let fileList: any = ref([]);
let limitFile: any = ref(3);
const onChangeFun = (file: any, list: any) => {
  // 判断上传文件是否已存在
  let existFile = list
      .slice(0, list.length - 1)
      .find((f: any) => f.name === file.name);
  if (existFile) {
    useMessage().error("当前文件已经存在!");
    list.pop();
  }
  fileList = list;
};
const submitFileForm = () => {
  if (!fileList.length) {
    useMessage().error("请上传至少一个文件!");
    return;
  }
  let formData = new FormData();
  fileList.forEach((item: any) => {
    formData.append("file", item.raw);
  });
  formData.append('id', '');
  // 这里写接口逻辑,将formData传给后端
}
const handleExceed = () => {
  useMessage().error(`最多上传${limitFile}个文件,请删除后重新上传!`);
}
  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要控制上传文件类型,可以使用el-upload的file-list属性,它是一个数组,用于存储已上传的文件列表。通过监听before-upload事件,可以在上传之前对文件进行检查和筛选。 示例代码: ```html <template> <el-upload class="upload-demo" action="/upload" :file-list="fileList" :before-upload="beforeUpload" :on-success="onSuccess" :on-error="onError" :auto-upload="false"> <el-button slot="trigger" size="small" type="primary">选取文件</el-button> <el-button style="margin-left: 10px;" size="small" type="success" @click="uploadFiles">上传到服务器</el-button> </el-upload> </template> <script> export default { data() { return { fileList: [] }; }, methods: { beforeUpload(file) { // 判断文件类型是否符合要求 const isJpgOrPng = file.type === 'image/jpeg' || file.type === 'image/png'; const isLt2M = file.size / 1024 / 1024 < 2; if (!isJpgOrPng) { this.$message.error('上传头像图片只能是 JPG/PNG 格式!'); return false; } if (!isLt2M) { this.$message.error('上传头像图片大小不能超过 2MB!'); return false; } // 添加到fileList中 this.fileList.push(file); return false; }, onSuccess() { this.$message.success('上传成功'); }, onError() { this.$message.error('上传失败'); }, uploadFiles() { // 执行上传操作 this.$refs.upload.submit(); } } }; </script> ``` 在before-upload事件中,我们检查了文件类型和大小,如果符合要求,则将文件添加到fileList中。在上传之前,我们可以通过遍历fileList来控制上传的文件类型。 另外,我们将auto-upload属性设置为false,这样选择文件后不会自动上传,而是需要手动调用submit方法上传文件。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值