element-ui大文件上传 单个文件

本文介绍了如何使用ElementPlus的上传组件实现文件分块上传,并通过自定义`before-upload`和`http-request`钩子来控制上传过程,包括文件大小限制、进度跟踪和错误处理。
<template>
  <el-upload ref="uploadRef" class="upload-demo" action="" :auto-upload="false" :show-file-list="false"
    :http-request="handleUploadRequest" :before-upload="handleBeforeUpload">
    <template #trigger>
      <el-button type="primary">选择文件</el-button>
    </template>
    <el-button class="ml-3" type="success" @click="submitUpload">
      上传文件{{ progressNum }}
    </el-button>
    <template #tip>
      <div class="el-upload__tip">
        文件大小限制 500kb
      </div>
    </template>
  </el-upload>
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import type { UploadInstance } from 'element-plus';

const uploadRef = ref<UploadInstance>();
// 文件对象
const fileValue = ref<File | null>(null);
// 分片大小
const chunkSize = ref<number>(1024 * 1024);
// 总分片数量
const totalChunks = ref<number>(0);
// 当前分片索引
const currentChunk = ref<number>(0);
// 进度条值
const progressNum = ref<number>(0);

// 设置beforeUpload钩子函数以获取选中的文件
const handleBeforeUpload = (file: File) => {
  console.log(file, '-00-0-0-11111');
  fileValue.value = file;
  handleFileChange(file);
  return false; // 阻止默认上传行为,因为我们使用自定义的http-request
};

// 在选择文件后计算总分片数
const handleFileChange = (file: File) => {
  console.log(file, '-0-0-0-0');
  if (!file) return;
  totalChunks.value = Math.ceil(file.size / chunkSize.value);
};

// 提交上传
const submitUpload = () => {
  uploadRef.value!.submit()
  if (fileValue.value) {
    currentChunk.value = 0;
    handleUploadRequest();
  }
};

// 自定义上传请求方法
const handleUploadRequest = async () => {
  if (!fileValue.value || currentChunk.value >= totalChunks.value) return;

  const start = currentChunk.value * chunkSize.value;
  const end = Math.min(fileValue.value.size, start + chunkSize.value);
  const chunk = fileValue.value.slice(start, end);

  const formData = new FormData();
  formData.append('file', chunk as Blob);
  formData.append('chunk', currentChunk.value.toString());
  formData.append('totalChunks', totalChunks.value.toString());
  formData.append('fileName', fileValue.value.name);

  if (true) {
    // 更新当前分片索引和进度
    currentChunk.value++;
    progressNum.value = (currentChunk.value / totalChunks.value) * 100;
    // 如果所有分片都已上传,则触发最终的完成逻辑(此处仅作示例,实际应用中根据服务器返回进行处理)
    if (currentChunk.value === totalChunks.value) {
      console.log('全部分片已上传完成');
    }
  } else {
    console.error('Error uploading chunk');
  }
};
</script>

### 使用 Element UI 实现单个图片文件上传 为了实现单个图片文件上传功能,可以利用 `el-upload` 组件并配置相应的属性来满足需求。下面是一个详细的例子说明如何设置该组件以及必要的事件处理器。 #### HTML 部分 定义一个简单的表单项用于展示和操作待上传的图片: ```html <template> <div> <!-- 单张图片上传 --> <el-upload class="avatar-uploader" action="http://192.168.60.27:8888/file-storage-center/object/uploadObjectByMultipartFile" :show-file-list="false" :on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload"> <img v-if="imageUrl" :src="imageUrl" class="avatar"> <i v-else class="el-icon-plus avatar-uploader-icon"></i> </el-upload> <p><span>*</span> 身份证国徽面</span></p> </div> </template> ``` 此模板中的 `<el-upload>` 设置了几个重要属性: - `action`: 指定服务器端接收上传请求的URL[^2]。 - `:show-file-list="false"`: 不显示默认的文件列表,因为这里只允许上传一张图片[^3]。 - `:on-success="handleAvatarSuccess"` 和 `:before-upload="beforeAvatarUpload"`: 定义两个回调函数分别处理上传成功的逻辑和上传之前的校验逻辑[^1]。 #### JavaScript (Vue.js) 部分 接下来是在 Vue 的 script 中编写对应的业务逻辑: ```javascript <script> export default { data() { return { imageUrl: '' }; }, methods: { // 成功后的钩子函数 handleAvatarSuccess(res, file) { this.imageUrl = URL.createObjectURL(file.raw); }, // 文件上传前的拦截器 beforeAvatarUpload(file) { const isJPG = file.type === 'image/jpeg'; const isLt2M = file.size / 1024 / 1024 < 2; if (!isJPG) { this.$message.error('仅支持 JPG 格式的图片!'); } if (!isLt2M) { this.$message.error('图片大小不得超过 2MB!'); } return isJPG && isLt2M; } } } </script> ``` 这段脚本实现了如下功能: - 当图片成功上传后更新界面上显示的图片链接; - 对即将上传文件做类型和尺寸上的初步检验,不符合条件则阻止继续上传,并给出提示信息; #### CSS样式部分 最后添加一些基本样式让上传区域看起来更美观: ```css <style scoped> .avatar-uploader .el-upload { border: 1px dashed #d9d9d9; border-radius: 6px; cursor: pointer; position: relative; overflow: hidden; } .avatar-uploader .el-upload:hover { border-color: #409EFF; } .avatar-uploader-icon { font-size: 28px; color: #8c939d; width: 178px; height: 178px; line-height: 178px; text-align: center; } .avatar { width: 178px; height: 178px; display: block; } </style> ``` 上述代码片段展示了完整的解决方案,包括HTML结构、JavaScript行为控制及CSS外观设计三方面的工作,从而完成基于Element UI框架下的单一图像文件上传特性开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猛男敲代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值