el-table 表格加图片、加音频、加序号、多级动态表头
elemnet-ui组件库大家应该不陌生,在展示多条结构类似的数据方面,el-table可谓扛把子,不仅可以把数据展示的整齐,还支持排序、筛选或其他自定义操作。那么,除了上述的基本功能外,你还遇到过哪些花样的需求呢?下面我们一起盘点下吧~
1 基本使用
如果熟悉基本操作,可直接看下面第二小节。
<template>
<el-table:data="tableData" style="width: 100%">
<el-table-column prop="date" label="日期"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address"label="地址"></el-table-column>
</el-table>
</template>
<script>
export default {
data() {
return {
tableData: [
{date: '2016-05-02',name: '王小虎',address: '上海市普陀区金沙江路 1518 弄'},
{date: '2016-05-04',name: '王小虎',address: '上海市普陀区金沙江路 1517 弄'},
{date: '2016-05-01',name: '王小虎',address: '上海市普陀区金沙江路 1519 弄'},
{date: '2016-05-03',name: '王小虎',address: '上海市普陀区金沙江路 1516 弄'}
]
}
}
}
</script>
2 表格数据排序,首行加序号
2.1 当前页排序
设置type属性为index即可显示从 1 开始的索引号。注意:此时如果表格有分页,当前序号只是对当前页的排序。而不是全部数据。每次翻页,序号都会从1开始。
2.2 全部数据排序
<el-table-column fixed label="序号"width="50" align="center">
<template scope="scope">
<span>{{scope.$index+(page - 1) * limit + 1}} </span>
</template>
</el-table-column>
scope.$index:当前行在当前页的序号
page:当前页数
limit:一页显示多少行
3 表格中显示图片
<el-table-column prop="photo" label="照片">
<template slot-scope="scope">
<img :src="scope.row.photo" width="40" height="40" alt=""/>
</template>
</el-table-column>
4 表格中添加开关(el-switch)
<el-table-column property="state" label="状态">
<template slot-scope="scope">
<el-switch v-model="scope.row.state"></el-switch>
</template>
</el-table-column>
5 表格中添加音频播放
通过上面2个实例,我们觉得scope很神奇,什么都可以放。此时如果想添加音频,是否可以直接播放呢?我们先了解一下几种常见的音频格式以及播放方式。
1 .mp3格式,H5的<audio>标签可直接播放。
2 .wav格式,该格式没办法直接播,只能先下载到本地,通过本地播放器播放。
鉴于以上情况,我们拿到音频数据后,需要先判断一下音频格式,再为其选用正确处理方式。
this.tableData.forEach((item) => {
// 接口返回值中,rowRecording字段 表示音频
let rowRecording = item.recording;
if (rowRecording === '') { // 字段值为空,页面显示‘暂无录音’
this.$set(item, 'showAudio', 0);
} else {
let arr = rowRecording.split('.'); // 拿到音频格式后缀
let recordTypeName = arr[arr.length - 1];
if (recordTypeName === 'mp3') { // mp3格式,直接播放
this.$set(item, 'showAudio', 1);
} else if (recordTypeName === 'wav') { // wav格式,提示下载
this.$set(item, 'showAudio', 2);
}
}
});
<el-table-column prop="recording" label="录音" width="120">
<template slot-scope="scope">
<div style="width: 100%;height: 32px;" v-if="scope.row.showAudio===1">
<audio controls style="width:100%;height: 100%;">
<source :src="scope.row.recording" type="audio/wav">
</audio>
</div>
<div v-if="scope.row.showAudio===2">
<a :href="scope.row.recording">点击下载播放</a>
</div>
<div v-if="scope.row.showAudio===0">暂无录音</div>
</template>
</el-table-column>
以上3种需求的实现效果如下:

6 动态生成多级表头
我们知道el-table支持多级表头,效果如下图,顺便我们讨论下多级表头时,表格是如何渲染的。下图中数字代表层级,如果此时我说不管表头有多少级,每一级表头只需要关心自己的直接子元素,以此类推,直到最后一级没有子元素的表头去匹配数据,整个表格就可以正确渲染,你觉得对吗?
也就是说,下图中,第一级表头“配送信息”只需正确找到自己的两个孩子“姓名”和“地址”....., 到了没有子元素的3-1“省份”,那它就负责去匹配数据。

原理我们已经理解,但是官方示例中表头都是在页面里写死的固定数据。实际应用中,很多情况下表头是是接口返回的。那此时,表头需要动态生成,且要保证层级正确,更重要的是,数据渲染要准确。
我们将直接层级关系的表头比喻成父子,那么将表头数据设计成相应的嵌套结构。通过双层for循环,多级表头是不是就可以正确渲染了呢?然后让最后一级表头去匹配数据,数据也就可以正确展示了吧?试一下吧~假设接口返回的多级动态表头数据结构如下:
tableHeader: [
{'label': '日期','prop': 'date'},
{
'label': '信息',
'prop': '信息',
children: [
{prop:"name",label:"姓名"},
{prop:"province",label:"省份"},
{prop:"city",label:"市区"},
{prop:"zip",label:"邮编"}
]
}
]
相信你已经看出谁有子元素了,下面看如何通过双层for循环渲染多级表头。
<el-table :data="tableList">
<el-table-column
v-for='item in tableHeader' :label="item.label"
:prop='item.prop' :key='item.prop'>
<template v-if='item.children && item.children.length'>
<el-table-column
v-for="item1 in item.children" :label="item1.label"
:prop='item1.prop':key='item1.prop'>
</el-table-column>
</template>
</el-table-column>
</el-table>
我们再给一组表格数据:
tableList: [
{
"date": "2020-06-01",
"name": "王小虎",
"province": "上海",
"city": "普陀区",
"zip": 200333
}
]
最终效果如下,完成!

欢迎大家关注我的公粽号,文章更早、更全,扫下面二维码或微信搜“Lemoncool” ,期待您的关注~
el-table 表格加图片、加音频、加序号、多级动态表头的更多相关文章
- el-table的花样需求---表格加图片、加音频、加序号、多级动态表头
elemnet-ui组件库大家应该不陌生,在展示多条结构类似的数据方面,el-table可谓扛把子,不仅可以把数据展示的整齐,还支持排序.筛选或其他自定义操作.那么,除了上述的基本功能外,你还遇到过哪 ...
- Html Table用JS导出excel格式问题 导出EXCEL后单元格里的000412341234会变成412341234 7-14 会变成 2018-7-14(7月14) 自定义格式 web利用table表格生成excel格式问题 js导出excel增加表头、mso-number-format定义数据格式 数字输出格式转换 mso-number-format:"\@"
Html Table用JS导出excel格式问题 我在网上找的JS把HTML Tabel导出成EXCEL.但是如果Table里的数字内容为0开的的导成Excel后会自动删除0,我想以text的格式写入 ...
- asp.net将内容导出到Excel,Table表格数据(html)导出EXCEL
代码: /// <summary> /// HTML Table表格数据(html)导出EXCEL /// </summary> /// <param name=&quo ...
- Bootstrap Table表格一直加载(load)不了数据-解决办法
bootstrap-table是一个基于Bootstrap风格的强大的表格插件神器,官网:http://bootstrap-table.wenzhixin.net.cn/zh-cn/ 这里列出遇到的一 ...
- 自设table表格,获取内容,并经弹出框的url传参,获取结果显示在弹出框,并加载合计
table表格,选择框 form id="editForm1"> <table class="table_form"> <td > ...
- layui table动态表头 改变表格头部 重新加载表格
改变头部原理: 删除原来表格, 重新建立DOM元素, 重新加载table,实现表头改变 明白了原理, 我相信大家都能写出来了, table.reload(ID, options)目前好像还不支持con ...
- 图片,音频资源预加载和文档dom加载
在项目中遇到一个问题,ajax请求音频资源,然后动态的插入到文档中,其中.原生的音频外观实在太丑了,而且每个浏览器的样式都不一样,采取了一个audio插件. 就遇到一个问题,请求后的直接调用插件的话, ...
- jquery实现表格导入到Excel(加图片)
话不多说直接上代码 第一步:导入jquery的插件https://github.com/rainabba/jquery-table2excel HTML部分: 第二步:添加一个按钮 <but ...
- JS怎样实现图片的懒加载以及jquery.lazyload.js的使用
在项目中有时候会用到图片的延迟加载,那么延迟加载的好处是啥呢? 我觉得主要包括两点吧,第一是在包含很多大图片长页面中延迟加载图片可以加快页面加载速度:第二是帮助降低服务器负担. 下面介绍一下常用的延迟 ...
随机推荐
- kubernetes pod的弹性伸缩———基于pod自定义custom metrics(容器的IO带宽)的HPA
背景 自Kubernetes 1.11版本起,K8s资源采集指标由Resource Metrics API(Metrics Server 实现)和Custom metrics api(Promet ...
- python3.x 基础七:面向对象进阶
类的高级方法: 1.静态方法:在类方法前增加关键字@staticmethod,将普通方法变成静态方法,不能再次传值,不能访问实例变量或者类变量,与类的关系仅仅是通过类名进行调用 2.类方法:在类方法前 ...
- javaScript(原型链)
在了解javaScript的原型链之前,我们得先来看一下原型是什么. 在javaScript中,所有的函数都会有着一个特别属性:prototype(显示原型属性):当我们运行如下代码时: functi ...
- Java并发编程入门(二)
1.竞态条件 1.1 定义 当某个计算的正确性取决于多个线程的交替执行时序时,就会发生竞态条件.换句话说,正确的结果要取决于运气. 最常见的竞态条件类型:先检查后执行(Check-Then-Act)操 ...
- 用开源软件TrinityCore在Debian 10上搭建魔兽世界8.3.0.34220的服务器
用开源软件TrinityCore在Debian 10上搭建魔兽世界8.3.0.34220的服务器 TrinityCore是魔兽世界(World of Warcraft)的开源的服务端.目前支持魔兽的3 ...
- ASP.NET Core on K8S学习之旅(14)Ingress灰度发布
本篇已加入<.NET Core on K8S学习实践系列文章索引>,可以点击查看更多容器化技术相关系列文章. 之前一篇介绍了Ingress的基本概念和Nginx Ingress的基本配置和 ...
- Oracle阻塞会话源头查找-单机和RAC环境
在写 Oracle session相关数据字典(一) 这篇文章时,提到使用v$session视图的树形查询可以得到Oracle锁树,这样就便于我们找出阻塞会话的源头,但是仅仅可以在单机环境中使用.今 ...
- 【Copy攻城狮日志】Node快速重命名文件,告别Potplay字幕困扰问题
↑开局一张图,故事全靠编↑ 前言 Copy攻城狮日志的惯例,开局一张图,开始为您讲述一个鲜为人知的故事.故事的开头要从本大狮从盗版网站下载udemy课程的犯罪伊始说起,去年的某月某天,我真正接触到了“ ...
- MySQL知识-redis实例
规划.搭建过程:6个redis实例,一般会放到3台硬件服务器注:在企业规划中,一个分片的两个分到不同的物理机,防止硬件主机宕机造成的整个分片数据丢失.端口号:7000-7005 # 1. 安装集群插件 ...
- Mysql的一次查询的过程
1.用户发起请求,这里往往时多线程并发访问 2.去数据库线程池拿数据库链接,如果没有线程池,每次访问都要和数据库建立一次连接,非常耗时,效率低下 3.数据库层面上来说,可能会有多个系统同时访问它,所以 ...