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

相关文章

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

GitLab文件的上传与下载方式

《GitLab文件的上传与下载方式》:本文主要介绍GitLab文件的上传与下载方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录GitLab 项目拉取到本地GitLab 项目上传方法方法 1:本地项目未初始化Git方法 2:本地项目已初始化GitGitLab 上

Nginx 413修改上传文件大小限制的方法详解

《Nginx413修改上传文件大小限制的方法详解》在使用Nginx作为Web服务器时,有时会遇到客户端尝试上传大文件时返回​​413RequestEntityTooLarge​​... 目录1. 理解 ​​413 Request Entity Too Large​​ 错误2. 修改 Nginx 配置2.1

Java应用如何防止恶意文件上传

《Java应用如何防止恶意文件上传》恶意文件上传可能导致服务器被入侵,数据泄露甚至服务瘫痪,因此我们必须采取全面且有效的防范措施来保护Java应用的安全,下面我们就来看看具体的实现方法吧... 目录恶意文件上传的潜在风险常见的恶意文件上传手段防范恶意文件上传的关键策略严格验证文件类型检查文件内容控制文件存储

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

Java实现MinIO文件上传的加解密操作

《Java实现MinIO文件上传的加解密操作》在云存储场景中,数据安全是核心需求之一,MinIO作为高性能对象存储服务,支持通过客户端加密(CSE)在数据上传前完成加密,下面我们来看看如何通过Java... 目录一、背景与需求二、技术选型与原理1. 加密方案对比2. 核心算法选择三、完整代码实现1. 加密上

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项

springboot上传zip包并解压至服务器nginx目录方式

《springboot上传zip包并解压至服务器nginx目录方式》:本文主要介绍springboot上传zip包并解压至服务器nginx目录方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录springboot上传zip包并解压至服务器nginx目录1.首先需要引入zip相关jar包2.然

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n