<template>
<div class="table-cooperte">
<el-table
:data="tableData"
stripe
style="width: 100%"
border
ref="table"
:span-method="objectSpanMethod"
tooltip-effect="dark"
:height="tableHeight"
:row-style="rowStyleHandel"
:header-cell-style="{background:'#ff0000',color: '#fff'}"
>
<el-table-column label="多级表头使用" align="center">
<el-table-column prop="date" label="日期" align="center"></el-table-column>
<el-table-column prop="name" label="姓名" align="center"></el-table-column>
<el-table-column prop="address" label="地址" align="center" min-width="50"></el-table-column>
<el-table-column fixed="right" label="操作" align="center" min-width="100">
<template slot-scope="scope">
<el-button @click="handleAdd(scope.row)" type="text" size="small">新增</el-button>
<el-button @click="handleDel(scope.$index)" type="text" size="small">删除</el-button>
</template>
</el-table-column>
</el-table-column>
</el-table>
<el-table
:data="tableData"
stripe
style="width: 100%"
border
ref="table1"
tooltip-effect="dark"
:height="tableHeight"
@selection-change="handleSelect"
:row-key="row => row.id"
:header-cell-style="{background:'#333',color: '#fff'}"
>
<el-table-column type="selection" width="55" align="center" :reserve-selection="true"></el-table-column>
<el-table-column type="index" label="序号" align="center"></el-table-column>
<el-table-column prop="date" label="日期" align="center"></el-table-column>
<el-table-column prop="name" label="姓名" align="center"></el-table-column>
<el-table-column prop="address" label="地址" align="center" min-width="50"></el-table-column>
<el-table-column fixed="right" label="操作" align="center" min-width="100">
<template slot-scope="scope">
<el-button @click="handleExport(scope.row)" type="text" size="small">导出</el-button>
</template>
</el-table-column>
</el-table>
</div>
</template> <script>
export default {
data() {
return {
tableHeight: 400,
tableData: [
{
id: 1,
date: "2016-05-02",
name: "王小7",
address: "上海市普陀区金沙江路 1518 弄"
},
{
id: 2,
date: "2016-05-04",
name: "王小虎2",
address: "上海市普陀区金沙江路 1517 弄"
},
{
id: 3,
date: "2016-05-01",
name: "王小虎",
address: "上海市普陀区金沙江路 1519 弄"
},
{
date: "2016-05-03",
name: "王小9",
address: "上海市普陀区金沙江路 1516 弄"
},
{
id: 4,
date: "2016-05-03",
name: "王小1",
address: "上海市普陀区金沙江路 1516 弄"
},
{
id: 5,
date: "2016-05-03",
name: "王小2",
address: "上海市普陀区金沙江路 1516 弄"
},
{
id: 6,
date: "2016-05-03",
name: "王小3",
address: "上海市普陀区金沙江路 1516 弄"
}
],
spanArr: [], // 合并数据
pos: 0, // 合并标记
multipleList: [], // 选中数据
}
},
created() {
this.getSpanArr(this.tableData);
},
mounted(){
/*
stripe 斑马纹属性
header-cell-style 表头样式
其他具体属性参照官网api调用
*/
},
methods: {
// 1、row-class-name 类名控制 2、row-style 样式控制
rowStyleHandel({ row, rowIndex }) {
// console.log(row,rowIndex)
if (row.name == "王小7") {
return "background:#999;color:#ff0000 !";
}
},
// 合并列
objectSpanMethod({ row, column, rowIndex, columnIndex }) {
if (columnIndex === 0) {
const _row = this.spanArr[rowIndex];
const _col = _row > 0 ? 1 : 0;
return {
rowspan: _row,
colspan: _col
};
}
},
getSpanArr(data) {
for (var i = 0; i < data.length; i++) {
if (i === 0) {
this.spanArr.push(1);
this.pos = 0;
} else {
// 判断当前元素与上一个元素是否相同 可以是data[i][0]和data[i - 1][0]比较或者类推
if ( data[i].date === data[i - 1].date) {
this.spanArr[this.pos] += 1;
this.spanArr.push(0);
} else {
this.spanArr.push(1);
this.pos = i;
}
}
}
},
// 选中 -- 若要 翻页记忆选中:row-key="row => row.id" 不一定是id可以是唯一属性区别 type="selection"加上:reserve-selection="true" 适用场景:列表页导出、批量操作 不适用于有回显的(新增编辑详情同一组件情况需要特别处理)
handleSelect(val){
console.log(val)
this.multipleList = val;
},
// 新增
handleAdd(row) {
this.tableData.push(row);
},
// 删除
handleDel(index) {
this.tableData.splice(index, 1);
},
// 导出 -- 设置响应体 responseType: 'blob', 需要先 cnpm i js-file-download -S 安装依赖
handleExport(row){
// 接口 返回成功后 写上下面代码
this.$message({
type: 'success',
message: '导出成功'
})
let fileDownload = require("js-file-download");
// console.log(res.headers['content-disposition'].split("=")[1],'头部')
fileDownload(res.data,decodeURIComponent(res.headers['content-disposition'].split("=")[1]));
},
}
};
</script> <style>
</style>

element ui表格常用功能如:导出 新增 删除 多选 跨页多选 固定表头 多级表头 合并行列 等常见需求的更多相关文章

  1. element ui 表格提交时获取所有选中的checkbox的数据

    <el-table ref="multipleTable" :data="appList" @selection-change="changeF ...

  2. Element UI表格组件技巧:如何简洁实现跨页勾选、跨页统计功能

    业务场景 在使用Element UI的Table组件时,常常面对这样的业务需求: 表格数据的每一项都要提供勾选框,当切换分页时,能够记忆所有页面勾选的数据,以实现批量提交不同页面勾选数据的功能.并且, ...

  3. vue2.0+Element UI 表格前端分页和后端分页

    之前写过一篇博客,当时对element ui框架还不太了解,分页组件用 html + css 自己写的,比较麻烦,而且只提到了后端分页 (见 https://www.cnblogs.com/zdd20 ...

  4. vue + element ui 表格自定义表头,提供线上demo

    前言:工作中用到 vue+element ui 的前端框架,需要使用自定义表头,需要使用 re.转载请注明出处:https://www.cnblogs.com/yuxiaole/p/9710826.h ...

  5. 封装一个优雅的element ui表格组件

    现在做后台系统用vue + elementUI 的越来越多,那element ui的 el-table 组件肯定也离不开.虽然element ui的table组件很好.但是表格和分页是分离的.每次写表 ...

  6. element UI表格行高、padding等设置报错问题

    element UI里面表格的行高需要自己调整高度和设置padding,直接写style是不行的,里面有 : 1.row-style (行的 style) 2.header-row-styl   (表 ...

  7. element ui表格表头顺序错乱的问题

    因为在项目中两个表格共用了同一个组件, 但由于表头不完全相同, 就通过v-if来控制表头的显示隐藏,没想到造成了表头顺序的错乱, 经过多方查找资料,最后找到了解决方法: 即为每一列el-table-c ...

  8. element ui表格实现单选 但是单选取消会报错

    1.在el-table中添加两个事件  @selection-change="handleSelectionChange"  @current-change="choos ...

  9. Element ui表格展示多张图片问题

    显示一张图片的方法: <el-table-column label="头像" width="100"> <template scope=&qu ...

随机推荐

  1. sublime中文解决

    1.写好文件sublime_imfix.c并保存. #include <gtk/gtkimcontext.h> void gtk_im_context_set_client_window ...

  2. Java8新特性之forEach+Lambda 表达式遍历Map和List

    这是Java8系列的第二篇,今天来说一下Java8中forEach的简单使用.我们使用对比的方式来看应该会看得更加清楚,更能理解: 一.遍历Map ============Java8之前的方式==== ...

  3. materialize 读取单选按钮

    $('input[name='xxx']:checked')

  4. MYSQL中group_concat( )函数中参数的排序方法

    使用mysql中的group_concat( )函数连接指定字段时,可以先对该字段进行排序. PS:是因为二刷mysql的51道题的第12题遇到的:查询和" 01 "号同学学习的课 ...

  5. Java中lambda表达式学习

    一.Lambda表达式的基础语法: Java8中引入了一个新的操作符"->"该操作符称为箭头操作符或Lambda操作符,箭头操作符将Lambda表达式拆分为两部分: 左侧:L ...

  6. A1016 | 磨人的大模拟

    这题写得头晕……明天我再评价 #include <stdio.h> #include <memory.h> #include <math.h> #include & ...

  7. Instance Segmentation with Mask R-CNN and TensorFlow

    Back in November, we open-sourced our implementation of Mask R-CNN, and since then it’s been forked ...

  8. fiddler自动生成jmeter测试脚本

    概述 昨天我们在课堂上讲了如何通过fiddler抓包,单一接口可以复制到jmeter中进行接口测试,那么如果抓包获取了大量的接口,我们如何快速实现接口转换成jmx文件呢? 今天给大家介绍fiddler ...

  9. 用Python画一颗特别的心送给她

    import numpy as np import matplotlib.pyplot as plt x_coords = np.linspace(-100, 100, 500) y_coords = ...

  10. Spring Boot Controller单元测试

    一.创建Controller 一个方法是用传统IO来下载文件,一个是NIO下载文件 @Controller public class FileController { private Logger l ...