element 附件上传/文件上传组件

2024-09-05 10:58
文章标签 组件 上传 element 附件

本文主要是介绍element 附件上传/文件上传组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实例:
在这里插入图片描述
组件代码:
在这里插入图片描述

<template><div><el-uploadclass="upload-demo"action="":auto-upload="false":on-change="submitFile":before-remove="handleRemove":limit="limit":on-exceed="handleExceed":file-list="fileList":show-file-list="showFile"><el-buttonicon="el-icon-upload2"style="position: absolute; left: 120px; top: 0px;">上传文件</el-button></el-upload></div>
</template><script>
export default {name: '',components: {},props: {limit: {type: Number,default: 1},fileList: {type: Array,default: function () {return []}},showFile: {type: Boolean,default: true},sizeLimit: {// 最大单文件大小type: Number,default: 50}},data () {return {file: ''}},created () {},mounted () {},methods: {beforeUpload (file) {console.log(file, 'file.name')return new Promise((resolve, reject) => {if (!/\.(jpg|jpeg|png|JPG|PNG|pdf|doc|docx)$/.test(file.name)) {// eslint-disable-next-line prefer-promise-reject-errorsthis.$message.warning('附件只支持JPG/JPEG/PNG/PDF/DOC/DOCX格式!')this.fileList = []return false}const filePost = file.name.substring(file.name.lastIndexOf('.') + 1)console.log(filePost, 'filePost')if (filePost === 'doc' || filePost === 'docx') {if (file.size > 10 * 1024 * 1024) {console.log(file.size, 'file.size')// eslint-disable-next-line prefer-promise-reject-errorsthis.$message.warning('上传word大小不能超过10M!')this.fileList = []return false}} else {if (file.size > this.sizeLimit * 1024 * 1024) {console.log(file.size, 'file.size')// eslint-disable-next-line prefer-promise-reject-errorsthis.$message.warning(`上传附件大小不能超过${this.sizeLimit}M!`)this.fileList = []return false}}// if (file.size > this.sizeLimit * 1024 * 1024) {//   console.log(file.size, 'file.size')//   // eslint-disable-next-line prefer-promise-reject-errors//   this.$message.warning(`上传图片大小不能超过${this.sizeLimit}M!`)//   this.fileList = []//   return false// }resolve()})},async submitFile (file, fileList) {// 获取上传的文件console.log(file, 'file')await this.beforeUpload(file)this.$emit('success', file, fileList)},handleRemove (file, fileList) {console.log(file, fileList, '移除前确认')return this.$confirm(`确定移除 ${file.name}`)},handleExceed (files, fileList) {this.$message.warning(`仅可上传${this.limit}个附件`)}}
}
</script><style lang='scss' scoped>
::v-deep .el-upload-list {margin-left: 46px;
}
</style>

页面调用:

import fileUpload from '@/components/fileUpload.vue'
components: { fileUpload }
<el-form-item label="上传附件:" class="accessory"><file-upload:fileList="accessory"@success="handlesuccess"></file-upload><divstyle="width: 300px;color: #999;margin-left: 120px;font-size: 12px;"><p>可上传本人简历,作品集及其他代表性附件内容</p><p>附件大小:DOC/DOCX小于10MB,其它小于50MB</p></div>
</el-form-item>
handlesuccess (file, fileList) { // 上传成功this.file = file
}

注意:我这里是单文件上传,如果是多文件的话,this.file应该是一个数组,删除的话从数组找file进行删除。。。还有,这里用的是手动上传,也就是在改变upload的时候是不会上传的,只会存在本地,在用户点击提交按钮后用formData处理后调用文件上传接口进行提交,这样做的好处是可以预防服务器脏数据。
实例:

// 附件上传async fileUpload () {const that = thisconst fileList = []fileList.push(this.file) // this.file 就是暂存的file文件if (fileList.length) {const params = new FormData()fileList.map(item => {params.append('attachment', item.raw) // attachment就是后端要的键名})const res = await serve.fileUploads(params) // 调后端接口进行上传if (res.data.code === 200) {that.enclosure = JSON.parse(JSON.stringify(res.data.data.url)) // 保存返回的filePath和表单一起提交} else {this.$loading().close()that.$message.warning(res.data.msg)}}},

处理成Promise,然后点击提交按钮后利用async,await先执行文件上传,等接口返回文件filePath后再和表单一起提交。

await this.fileUpload()

tips:
校验这块儿,如果大小是统一的话,建议删掉1,放开2
在这里插入图片描述

这篇关于element 附件上传/文件上传组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138765

相关文章

input的accept属性让文件上传安全高效

《input的accept属性让文件上传安全高效》文章介绍了HTML的input文件上传`accept`属性在文件上传校验中的重要性和优势,通过使用`accept`属性,可以减少前端JavaScrip... 目录前言那个悄悄毁掉你上传体验的“常见写法”改变一切的 html 小特性:accept真正的魔法:让

JavaWeb 中的 Filter组件详解

《JavaWeb中的Filter组件详解》本文详细介绍了JavaWeb中的Filter组件,包括其基本概念、工作原理、核心接口和类、配置方式以及常见应用示例,Filter可以实现请求预处理、响应后... 目录JavaWeb 中的 Filter 详解1. Filter 基本概念1.1 什么是 Filter1.

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

java对接Pinata上传文件到IPFS全过程

《java对接Pinata上传文件到IPFS全过程》本文详细介绍了如何使用PinataAPI将文件上传到IPFS网络,首先登录Pinata官网并生成JWT令牌,然后在项目中导入OkHttp依赖并编写代... 目录1.登录2.生成令牌3.导入依赖4.编写代码5.调用接口调试China编程代码总结Pinata调用AP

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu