当前位置: 首页 > article >正文

elementUI——upload限制图片或者文件只能上传一个——公开版

最近在写后台管理系统时,遇到一个需求,就是上传图片,有且仅能上传一张。

效果图如下:
在这里插入图片描述
在这里插入图片描述
功能描述:上传图片时,仅支持单选,如果上传图片成功后,展示图片,并隐藏添加图片的按钮。删除图片后,上传按钮展示。

html部分代码

 <el-upload action="/file/Upload?module=EQ" accept="image/jpeg,image/jpg,image/png" :limit="1" :on-change="handleLimit" :class="{disabled:eqObj.uploadDisabled}" list-type="picture-card" :on-success="handleSuccess" :on-remove="handleRemove">
    <i class="el-icon-plus"></i>
</el-upload>
1.action:上传图片的地址,也可以使用`http-request`方法覆盖原有支持的上传函数

2.accept:上传图片支持的格式,如果是上传文件,也可以写文件的格式,用于选择图片或者文件时的筛选

3.limit:显示文件上传的个数,这个个数仅限制本次上传的个数,而非总数,因此还需要根据on-change函数进行判断

4.on-change:监听on-change(文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用)函数,来判断已经上传的数目

5.list-type:文件列表的类型,有text/picture/picture-card三种类型

6.on-success:文件上传成功后的回调函数,上传成功后可以拿到对应图片的线上地址,用于赋值给对应的参数

7.on-remove:删除文件,如果删除文件后的回调函数

css部分代码

.disabled .el-upload.el-upload--picture-card {
    display: none !important;
}

.disabled .el-button--success.is-plain {
    display: none !important;
}

如果添加了disabled的类名,则可以将添加图片的样式进行隐藏,就可以实现仅能上传特定数目了

js部分代码

限制文件个数,可以通过监听on-change事件来处理:

 handleLimit(file, fileList) {
    if (fileList.length >= 1) {
        this.eqObj.uploadDisabled = true;
        this.$set(this.eqObj, 'uploadDisabled', true);
    } else {
        this.eqObj.uploadDisabled = false;
        this.$set(this.eqObj, 'uploadDisabled', false);
    }
    this.$forceUpdate();
},

图片上传成功后的回调:

handleSuccess(response, file, fileList) {
    if (response.success) {
        this.eqForm.image = response.filepath;
    }
},

删除图片后的回调:

handleRemove(file, fileList) {
    console.log(file, fileList);
    this.eqObj.uploadDisabled = false;
    this.$forceUpdate();
},

注意:如果通过this.$set无法将对象的参数改变,则可以使用this.$forceUpdate()的方式来处理

按钮样式的上传功能:

在这里插入图片描述

html部分代码

<el-upload class="upload-demo" style="margin-top:4px;display:inline-block;" :show-file-list="false"
           action="/file/Upload?module=NoMainPackagePic" :file-list="[]"
           multiple
           :on-success="onSuccess">
    <el-button size="mini" type="success" plain>上传图片</el-button>
</el-upload>

完成!!!


http://www.kler.cn/a/455539.html

相关文章:

  • 【Android】application@label 属性属性冲突报错
  • HuaWei、NVIDIA 数据中心 AI 算力对比
  • 【unity c#】深入理解string,以及不同方式构造类与反射的性能测试(基于BenchmarkDotNet)
  • 为什么要在PHY芯片和RJ45网口中间加网络变压器
  • Android --- 在AIDL进程间通信中,为什么使用RemoteCallbackList 代替 ArrayList?
  • 新品:SA628F39大功率全双工音频传输模块
  • 新浪微博大数据面试题及参考答案(数据开发和数据分析)
  • 加强版第十七章空间色彩转换
  • 水电站视频智能监控系统方案设计与技术应用方案
  • 高频生活场景带动低频金融服务,美团企业版点燃场景金融建设引擎
  • Network Slice | Android 网络切片流程简介和日志分析
  • 【模电刷题复习--填空】
  • 04软件测试需求分析案例-用户登录
  • Word批量更改公式字体为Times New Roman
  • 领域自适应
  • 掌握Docker命令与Dockerfile实战技巧:快速构建高效容器化应用
  • 网络攻防环境搭建
  • 探索寄存器读写函数:writeb, writew, writel 与 readb, readw, readl
  • Debian系统宝塔面板安装LiteSpeed Memcached(LSMCD)
  • 5、栈应用-表达式求值
  • VSCode搭建Java开发环境 2024保姆级安装教程(Java环境搭建+VSCode安装+运行测试+背景图设置)
  • 如何安全获取股票实时数据API并在服务器运行?
  • Microsoft word@【标题样式】应用不生效(主要表现为在导航窗格不显示)
  • React里使用lodash工具库
  • 嵌入式学习-QT-Day05
  • 【2024年最新】BilibiliB站视频动态评论爬虫