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

相关文章

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用

Java文件上传的多种实现方式

《Java文件上传的多种实现方式》文章主要介绍了文件上传接收接口的使用方法,包括获取文件信息、创建文件夹、保存文件到本地的两种方法,以及如何使用Postman进行接口调用... 目录Java文件上传的多方式1.文件上传接收文件接口2.接口主要内容部分3.postman接口调用总结Java文件上传的多方式1

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-

vue2 组件通信

props + emits props:用于接收父组件传递给子组件的数据。可以定义期望从父组件接收的数据结构和类型。‘子组件不可更改该数据’emits:用于定义组件可以向父组件发出的事件。这允许父组件监听子组件的事件并作出响应。(比如数据更新) props检查属性 属性名类型描述默认值typeFunction指定 prop 应该是什么类型,如 String, Number, Boolean,

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除