我的编程空间,编程开发者的网络收藏夹
学习永远不晚

element-ui el-upload实现上传文件及简单的上传文件格式验证功能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

element-ui el-upload实现上传文件及简单的上传文件格式验证功能

在后台管理系统中总是会用到上传文件的功能,

想实现的样式如下:(实现上传文件后,在input输入框显示文件名 )

结构代码如下:

 <el-form-item label="使用说明" class="uploadMain" prop="instruction">
              <el-input
                class="uploadInput"
                v-model="productVO.instruction"
                style="width: 75%"
                placeholder="请上传pdf格式的使用说明文件"
                :disabled="true"
              >
                <el-upload
                  slot="append"
                  class="uploadbox"
                  ref="upload"
                  name="file"
                  accept=".pdf"    //接受上传文件的格式,此处会默认打开上传时筛选.pdf格式
                  :show-file-list="false"
                  :multiple="false"  //如果想要一次选择多个文件 mulitiple为true
                  action="upload"
                  :on-change="onChange"
                  :auto-upload="false"  //自动上传,如果此处为true 选择完文件就直接上传了
                >
                  <!-- class="uploadbtn" -->
                  <el-button class="uploadbtn"></el-button>
                </el-upload>
              </el-input>
            </el-form-item>

由于上述结构代码打开上传文件时会自动筛选accept的文件格式,但是在用户选择时仍可以自己选择全部文件,所以需要前端对上传文件进行初步的格式检验

前端部分上传文件初步检验js代码如下:

onChange(file) {
            // 校验格式
            if (['application/pdf'].indexOf(file.raw.type) == -1) {
                this.$message.error('请上传正确的pdf格式');
                return false;
            }
            this.productVO.instruction = file.name;
            this.productVO.instructionFile = file.raw; //上传文件时需要用到二进制,所以这里文件取值为file.raw
        },

上传至接口时js代码如下:

submit(){
     const formData = new FormData();
     formData.append('instruction', this.productVO.instruction);
     formData.append('instructionFile',this.productVO.instructionFile);
    
 
     //调用接口
     this.$post('/product/create',formData,{
         baseURL:'/',
         header:{isloading: true,'Content-Type': 'multipart/form-data'}).then()
}

 ".doc"

"application/msword"

".xls"

 "application/vnd.ms-excel"

".docx"

 "application/vnd.openxmlformats-officedocument.wordprocessingml.document"

".xlsx"

 "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"

".jpeg"

 "image/jpeg"

".mp3"

"audio/x-mpeg"

".jpg"

 "image/jpeg"

".mp4"

"video/mp4"

".png"

 "image/png"

 ".pdf" "application/pdf"

".ppt"

"application/vnd.ms-powerpoint"

 ".txt"

"text/plain"

".tar"

"application/x-tar"

".wps"

"application/vnd.ms-works"

".zip"

 "application/x-zip-compressed"

".xml"

 "text/plain"

附加:当上传文件为多个时,具体代码如下:

<el-form-item label="数据" class="uploadMain" prop="entity">
              <el-input
                class="uploadInput"
                v-model="productVO.entity"
                style="width: 75%"
                placeholder="请上传完整的tif/tiff/shp格式的数据文件"
                :disabled="true"
              >
                <el-upload
                  slot="append"
                  class="uploadbox"
                  ref="upload"
                  name="file"
                  accept=".tif,.tiff,.shp,.dbf,.prj,.sbn,.sbx,.shx"
                  :show-file-list="false"
                  multiple
                  :file-list="this.productVO.fileList"
                  action="upload"
                  :on-change="onChange"
                  :auto-upload="false"
                >
                  <!-- class="uploadbtn" -->
                  <el-button class="uploadbtn"></el-button>
                </el-upload>
              </el-input>
              <div style="color: #ffc230">此处是文本说明</div>
            </el-form-item>

js代码如下:

onChange(file,fileList) {
            // 校验格式
            if (['image/tiff', ''].indexOf(file4.raw.type) == -1) {
                this.$message.error('请上传正确的tif/tiff/shp格式');
                return false;
            }else{
                this.productVO.fileList=fileList
                console.log(this.productVO.fileList)
                var listName=[]
                this.productVO.fileList.forEach(function(e){listName.push(e.name)})
                var listFileRaw=[]
                this.productVO.fileList.forEach(function(e){listFileRaw.push(e.raw)})
                this.productVO.entity = listName; //文本框显示所有的文件名
                this.productVO.entityFile = listFileRaw;
            }
           
        },

接口上传文件时formData传参改动如下:

 this.productVO.entityFile.forEach(element => {
                        formData.append('entityFile', element)
                      })

总结

到此这篇关于element-ui el-upload实现上传文件及简单的上传文件格式验证功能的文章就介绍到这了,更多相关element-ui el-upload上传文件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

element-ui el-upload实现上传文件及简单的上传文件格式验证功能

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

element-ui el-upload实现上传文件及简单的上传文件格式验证功能

前端上传文件后,后端接受文件进行处理后直接返回处理后的文件,前端直接再将文件下载下来,下面这篇文章主要给大家介绍了关于element-ui el-upload实现上传文件及简单的上传文件格式验证功能的相关资料,需要的朋友可以参考下
2022-11-16

vue怎么使用el-upload实现文件上传功能

这篇文章主要介绍了vue怎么使用el-upload实现文件上传功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue怎么使用el-upload实现文件上传功能文章都会有所收获,下面我们一起来看看吧。uploa
2023-06-30

Servlet实现简单文件上传功能

本文实例为大家分享了Servlet文件上传的具体代码,供大家参考,具体内容如下两点要素: 1.表单提交方式必须是post 2.enctype一定要是multipart/form-data。 enctype的默认值是application/x
2023-05-30

JavaWeb怎么实现简单文件上传功能

这篇文章主要讲解了“JavaWeb怎么实现简单文件上传功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaWeb怎么实现简单文件上传功能”吧!1.概述通常浏览器上传的所有参数,我们可以
2023-07-02

JavaWeb怎么实现简单上传文件功能

这篇文章主要介绍了JavaWeb怎么实现简单上传文件功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaWeb怎么实现简单上传文件功能文章都会有所收获,下面我们一起来看看吧。基本思想:网站服务器的内部除了
2023-07-02

nodejs如何实现简单的文件上传功能

这篇文章主要为大家展示了“nodejs如何实现简单的文件上传功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“nodejs如何实现简单的文件上传功能”这篇文章吧。首先需要大家看一下目录结构,然后
2023-06-29

JavaWeb 文件的上传和下载功能简单实现代码

一、文件的上传和下载1、文件上传的原理分析 1、文件上传的必要前提: a、提供form表单,method必须是post b、form表单的enctype必须是multipart/form-data
2023-05-31

如何使用MySQL和Java实现一个简单的文件上传功能

使用MySQL和Java实现文件上传本文介绍如何使用MySQL数据库和Java编程语言实现文件上传功能。通过创建一个数据库表、配置Servlet来处理文件上传请求、创建HTML表单来允许用户选择文件,以及将文件数据存储到数据库,可以轻松实现文件上传的功能。本文还提供了必要的SQL语句、Java代码和HTML表单代码示例,以便于读者理解和实施。
如何使用MySQL和Java实现一个简单的文件上传功能
2024-04-12

如何使用MySQL和Java实现一个简单的文件上传功能

要使用MySQL和Java实现一个简单的文件上传功能,可以按照以下步骤进行:1. 创建一个MySQL数据库表来存储上传的文件信息。表可以包含字段如下:- id:文件ID,主键- filename:文件名- filepath:文件在服务器上的
2023-10-20

java开发之spring webflow如何实现上传单个文件及多个文件功能

这篇文章主要介绍java开发之spring webflow如何实现上传单个文件及多个文件功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:上传单个文件准备1. 如果你项目中使用了spring securit
2023-05-30

编程热搜

目录