ElementUI的Table组件行合并上手指南

ElementUI的Table组件行合并 ,示例用官网vue3版的文档

javascript 复制代码
<el-table :data="tableData" :span-method="objectSpanMethod" border style="width: 100%; margin-top: 20px">
    <el-table-column prop="id" label="ID" width="180" />
    <el-table-column prop="name" label="姓名" />
    <el-table-column prop="amount1" label="数值 1(元)" />
    <el-table-column prop="amount2" label="数值 2(元)" />
    <el-table-column prop="amount3" label="数值 3(元)" />
</el-table>
javascript 复制代码
export default {
    data() {
        return {
            tableData: [
                {
                    id: '12987122',
                    name: '王小虎',
                    amount1: '234',
                    amount2: '3.2',
                    amount3: 10,
                },
                {
                    id: '12987123',
                    name: '王小虎',
                    amount1: '165',
                    amount2: '4.43',
                    amount3: 12,
                },
                {
                    id: '12987124',
                    name: '王小虎',
                    amount1: '324',
                    amount2: '1.9',
                    amount3: 9,
                },
                {
                    id: '12987125',
                    name: '王小虎',
                    amount1: '621',
                    amount2: '2.2',
                    amount3: 17,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
                {
                    id: '12987126',
                    name: '王小虎',
                    amount1: '539',
                    amount2: '4.1',
                    amount3: 15,
                },
            ],

            // 用于行合并的数组,那就要在某一列下使用,此例子用于第一、二列
            // 每个元素是一行,0标识要隐藏第一列,非0数字标识此行要合并的行数
            spanArr: [3, 0, 0, 2, 0, 2, 0, 1, 3, 0], // 比如开头的3,0,0 从第一行开始合并3行,隐藏第二三行的第一列
            spanArr2: [2, 0, 1, 1, 1, 2, 0, 1, 1, 2],
        };
    },
    methods: {
		// 行合并范例
        objectSpanMethod({ row, column, rowIndex, columnIndex }) {
        	// 处理第一列
            if (columnIndex === 0) {
                let _row = this.spanArr[rowIndex];
                let _col = _row > 0 ? 1 : 0; // 0表示隐藏
                return {
                    rowspan: _row,
                    colspan: _col,
                };
            }
            
			// 处理第二列
            if (columnIndex === 1) {
                let _row = this.spanArr2[rowIndex];
                let _col = _row > 0 ? 1 : 0; // 0表示隐藏
                return {
                    rowspan: _row,
                    colspan: _col,
                };
            }
        },
    },
};

效果:

相关推荐
码农秋19 小时前
Element Plus DatePicker 日期少一天问题:时区解析陷阱与解决方案
前端·vue.js·elementui·dayjs
招风的黑耳2 天前
基于 Axure 与 Element UI 风格的拖动行排序表格设计
elementui·axure·表格·拖动
我是小路路呀2 天前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
暴富的Tdy3 天前
【使用 Vue2 脚手架创建项目并实现主题切换功能涵盖Ant-Design-Vue2/Element-UI】
vue.js·elementui·anti-design-vue·vue切换主题
小魏的马仔3 天前
【elementui】el-date-picker日期选择框,获取焦点后宽度增加问题调整
前端·vue.js·elementui
道之极万物灭4 天前
NiceGUI之Button操作(ElementPlus组件库)
python·elementui·web组件·nicegui
芳草萋萋鹦鹉洲哦4 天前
【elementUI】form表单rules没生效
前端·javascript·elementui
一只小阿乐5 天前
前端vue3 web端中实现拖拽功能实现列表排序
前端·vue.js·elementui·vue3·前端拖拽
方安乐6 天前
vue3 el-select懒加载以及自定义指令
javascript·vue.js·elementui
哆啦A梦15886 天前
商城后台管理系统 02 添加规格参数-动态表单
javascript·vue.js·elementui