el-upload上传列表实现 展开 收起
| # el-upload上传列表实现 展开 收起 |
|---|
| #### 无图言*,所以先上最终效果图(想参考代码的可以直接滑到最后) |
![]() |
| ### 具体实现思路 |
| 注意: 每个人的项目环境以及需求,都不尽相同,所以这里仅仅提供思路. |
| #### 看看没有收起之前 |
![]() |
| 可以看到,没有实现收起之前,如果一直上传文件,文件列表会一直向下延伸....... |
| 如果需求的上传数量少的话,还可以接受,但是,让我们看看需求 |
![]() |
| ???? 30 张 |
![]() |
| 可见,为了尽可能的减少对页面的影响,只能弄个展开以及收起了! |
| #### 思考 |
| 展开以及收起,无非是控制显示数量,那么我们就要对症下药,先看看什么属性与上传的文件数量有关 |
| 这时候我们就要去看 element-ui 的文档了 |
| 这里可以看到 file-list 这个属性与我们的上传文件列表有关,那我们就从它下手! |
| 这里我们用 slice() 方法 试试 |
| 关键代码: |
| 注意:我这因为有多项附件要上传,所以列表是个数组 |
| 相应的每一项是一个item,所以这里item.accessory才是我图片存储的地方 |
| 根据你们的实际数据格式看着来,不要完全照抄 |
| ```vue |
| :file-list="item.accessory.slice(0, 1)" |
| ``` |
![]() |
| 随后可以看到,不管我们怎么上传图片,只会显示第一张 |
| 那么到这里,我们限制显示数量的需求达到了 |
| 然后不要着急,这时候我们先去弄个按钮出来,饭要一口一口吃嘛 |
| 关键代码: |
| ```vue |
| // textFlg 是我自定的 类似于开关 |
| <div v-show="item.accessory.length > 1" class="more" @click="res=>{item.textFlg = !item.textFlg}"> |
| ``` |
| 这个按钮的整体思路是,只有上传图片大于1张才显示; 默认显示当前上传的文件数量-1;每当点击之后,切换状态. |
![]() |
| 之后就能实现这种效果,样式啥的我就不在这里展开了,主要是传递一个思路! |
| 限制显示数量又了,切换效果有了,那么现在就剩展开了! |
| 上面我们这条代码吗? |
| ```vue |
| :file-list="item.accessory.slice(0, 1)" |
| ``` |
| 这里我们将 slice() 方法 的第二个参数 固定成了 1 ; 这样就始终只显示一条! |
| 那么我们要是根据某个状态来切换这个1,不就达到我们想要的展开了嘛? |
| 说干就干! |
| 经过一番摸索之后! 实现了切换显示数量 |
| ```vue |
| :file-list="item.accessory.slice(0, item.textFlg ? item.accessory.length : 1)" |
| ``` |
| 这里三元表达式的意思是 textFlg === true 吗? 如果为true 就显示与上传列表数组长度相等的数据 :(否则) 显示1 |
| textFlg 就是我们用来控制按钮文字的状态,所以毫无疑问他们俩可以共用! |
| 至此,我们就实现了如最终效果图的切换 |
![]() |
| 以上,就是大概的实现思路,当然例如样式之类的等等细节,本文都选择直接略过,还请谅解. |
| 最后我会贴出我的所有代码,以及数据格式. |
| 当然,这肯定不是最优解,不过这是我的思路,有别的观点或者解决方案欢迎讨论~ |
| ### 仅供参考! 仅供参考! 仅供参考! |
| 我的数据格式: |
| ```json |
| details:[ |
| textFlg: false, |
| ] |
| ``` |
| 我的示例源码: |
| ```vue |
| <el-upload |
| ref="upload" |
| list-type="text" |
| :style="{ width: item.accessory.length > 1 ? '140px' : '100%' }" |
| :action="$store.state.config.uploadConfig.actionUrl" |
:headers="{ Authorization: Bearer ${$store.state.token} }" |
| :on-preview="handlePreview" |
| :auto-upload="true" |
| :file-list="item.accessory.slice(0, item.textFlg ? item.accessory.length : 1)" |
| :on-success=" |
| (res, file) => { |
| return handleSuccess(res, i, file) |
| } |
| " |
| :on-remove="handleRemove" |
| :before-upload="beforeAvatarUpload" |
| multiple |
| :limit="30" |
| :on-exceed="handleExceed" |
| :disabled="!isEdit" |
| > |
| <div v-show="item.accessory.length > 1" class="more" @click="more(item)"> |
{{ item.textFlg ? '收起' : +${item.accessory.length - 1} }} |
| ``` |
| 样式: |
| ```css |
| .more { |
| margin: 0 0 0 110px; |
| cursor: pointer; |
| width: 45px; |
| height: 20px; |
| background: #ebeef5; |
| text-align: center; |
| border-radius: 5px; |
| position: absolute; |
| bottom: 12px; |
| right: 5px; |
| } |
| ``` |
| 如果能帮到你,是我最大的荣幸! |
el-upload上传列表实现 展开 收起的更多相关文章
- 使用elementUI的时候,使用Upload 上传的时候,使用 list-type 属性来设置文件列表的样式,before-upload方法失效
最近在做项目的时候,使用elementUI的时候,使用Upload 上传的时候,before-upload方法失效. 情况下:使用 list-type 属性来设置文件列表的样式. 最终的优化之后:(演 ...
- element-ui Upload 上传组件源码分析整理笔记(十四)
简单写了部分注释,upload-dragger.vue(拖拽上传时显示此组件).upload-list.vue(已上传文件列表)源码暂未添加多少注释,等有空再补充,先记下来... index.vue ...
- UI标签库专题四:JEECG智能开发平台 Upload(上传标签)
1. Upload(上传标签) 1.1. 參数 属性名 类型 描写叙述 是否必须 默认值 id string 上传控件唯一标示 是 null name string 控件name 是 null ...
- React实战之Ant Design—Upload上传_附件上传
React实战之Ant Design—Upload上传_附件上传 Upload组件大家都在官方文档中看过了,但写的时候还是会遇到许多问题,一些新手看了文档后感觉无从下手,本文过多的简绍就不说了,直接看 ...
- Struts Upload上传文件
1.Unable to find 'struts.multipart.saveDir' property setting. Defaulting to javax.servlet.context.te ...
- Nginx的Upload上传模块
前段时间做一个项目,需要上传文件,差不多需要20M左右,普通用php处理会比较麻烦,经常超时,而且大量占用资源.于是搜索了下,决定用nginx的upload上传模块来处理. 你可以在这里:http:/ ...
- And Design:拓荒笔记——Upload上传
And Design:拓荒笔记——Upload上传 上传前
- upload 上传 加token 在 :headers='headers' 注意 不要直接写$refs.upload.headers = {} 这样vue会警告 修改组件内部变量
upload 上传 加token 在 :headers='headers' 注意 不要直接写$refs.upload.headers = {} 这样vue会警告 修改组件内部变量 <Upload ...
- element-ui upload上传组件问题记录
element-ui upload上传组件遇到的问题
随机推荐
- [刷题] 237 Delete Nodes in a Linked List
要求 给定链表中的一个节点,删除该节点 思路 通过改变节点的值实现 实现 1 struct ListNode { 2 int val; 3 ListNode *next; 4 ListNode(in ...
- 配置trunk和access
配置trunk和access 拓扑图 PC地址设置 PC1 :192.168.1.1 vlan10 PC2 :192.168.1.2 vlan10 交换机配置 LSW3配置 <Huawei> ...
- 进入单用户模式修改root密码
进入单用户模式修改root密码 1.进入引导菜单界面2.按e进入grub,在linux或linux16那行结尾加上 rw init=/bin/bash,按Ctrl+x或F103.进入bash-4.3# ...
- Linux服务之DNS服务篇
一.DNS服务概述 DNS(Domain Name System)域名系统,在TCP/IP 网络中有非常重要的地位,能够提供域名与IP地址的解析服务. DNS 是一个分布式数据库,命名系统采用层次的逻 ...
- IDEA Git 项目实战场景
实战场景一:上班啦,从远程仓库克隆项目到本地仓库(Clone) 打开 IDEA,在 Check out from Version Control 下拉菜单选择 Git,如下: 在弹出窗口的 URL 地 ...
- Docker系列——Grafana+Prometheus+Node-exporter服务器告警中心(二)
在前一篇博文中介绍,服务器监控已经部署成功.如果每天都需要人去盯着服务情况,那也不太现实.既然监控平台已经部署好了,是不是可以自动触发报警呢? 在上一篇Prometheus架构中有讲到,核心组件之一: ...
- Qt 搜索框
一.前言 用户需要输入文本时,可使用QLineEdit控件进行编辑输入,缺点是样式相对单一. 在使用百度搜索输入框时,发觉比较人性化,故采用QLineEdt+QPushButton通过css样式实现自 ...
- Api网关Kong集成Consul做服务发现及在Asp.Net Core中的使用
写在前面 Api网关我们之前是用 .netcore写的 Ocelot的,使用后并没有完全达到我们的预期,花了些时间了解后觉得kong可能是个更合适的选择. 简单说下kong对比ocelot打动我的 ...
- String 是一个奇怪的引用类型
开局两张图,内容全靠刷! 马甲哥看到这样的现象,一开始还是有点懵逼. 这个例子,string是纯粹的引用类型,但是在函数传值时类似于值传递: 我之前给前后示例的内存变化图吧: 根因就是大多数高级语言都 ...
- Locust入门
Locust入门 Locust是一款Python技术栈的开源的性能测试工具.Locust直译为蝗虫,寓意着它能产生蝗虫般成千上万的并发用户: Locust并不小众,从它Github的Star数量就 ...





