el-table花式操作,含合并求和、双表齐动 等等

news2024/11/25 20:36:34

1.指定行单元格,合并求和

el-table,提供的行合并,我是没找到单元格可以合并求和的,就用了操作document来 合并单元格,大家可以参考参考

在这里插入图片描述
上面这张表,第1 2 两行,数据是一样的,3 4 两行是一样的,只是2 4 是每个月所有人数据合并求和了下

/*
     *指定第几行从第几个开始,每几个合并单元格,并求和
     * rowIndexArr    要哪几行合并,数组
     * startIndex     从第几个开始(一般排除与求和无关的 首列)
     * everyFew       每多少个求和并合并单元格
     * ref            table的ref值(不填写,就默认本页面是单表)
     */
    tableRowMerge(rowIndexArr, startIndex, everyFew, ref) {
      var table;
      if (ref) {
        table = this.$refs[ref].$el;
      } else {
        table = document.querySelector(".el-table");
      }
      // 清除合并单元格和隐藏的单元格
      var mergedCells = table.querySelectorAll(".merged-cell");
      mergedCells.forEach(function (cell) {
        cell.parentNode.removeChild(cell);
      });
      rowIndexArr.forEach((item) => {
        let row = table.querySelectorAll(".el-table__body-wrapper tbody tr")[
          item
        ];
        let cells = row.querySelectorAll("td");
        for (let j = startIndex; j < cells.length; j += everyFew) {
          let sum = 0;
          for (let k = j; k < j + everyFew && k < cells.length; k++) {
            sum += parseFloat(cells[k].innerText);
            cells[k].style.display = "none"; // 隐藏参与求和的单元格
          }
          let mergedCell = document.createElement("td");
          mergedCell.innerText = sum;
          mergedCell.colSpan = everyFew; // 合并everyFew个单元格
          mergedCell.classList.add("merged-cell");
          mergedCell.style.textAlign = "center";
          cells[j].insertAdjacentElement("afterend", mergedCell); // 插入合并后的单元格
        }
      });
    },

使用方法,我上面是24 两行,从第二列开始,每四个合并求个,所以代码是

  updated() {
    this.tableRowMerge([1, 3], 1, 4, "myTable");
  },

2.双表一起滑动

滑动条,多表同步
在这里插入图片描述

//methods 里面,监听滑动
listenerScroll() {
    this.dom2.addEventListener('scroll', () => {
        // 横滚
        this.dom1.scrollLeft = this.dom2.scrollLeft
        // 竖滚
        this.dom1.scrollTop = this.dom2.scrollTop
    })
}

//然后数据变化就给他同步滑动
updated() {
    this.dom1 = this.$refs.table.bodyWrapper;
    this.dom2 = this.$refs.table2.bodyWrapper;
    const table1 = this.$refs.table;
    // 隐藏水平滑动条
    table1.maxHeight = 'none'; // 或者设置为其他自定义高度
    table1.layout.scrollX = false;
    this.listenerScroll();
},

3.分页下,给最后一页给上总计

在这里插入图片描述
这就可以用上双表了,配合上面2,可以去掉其中一个水平条

<div class="table-container" style="width: 100%; overflow-x: auto;">
	<el-table :data="table" ref="table"></el-table>
	<div v-if="isLastPage && isLastRow">
		<el-table :data="table2" ref="table2"></el-table>
	</div>
</div>
//属性计算,计算是不是最后一页,是不是是有数据
computed: {
    isLastPage() {
        return this.table.page === Math.ceil(this.table.totalCount / this.table.rows);
    },
    isLastRow() {
        return this.table.data.length > 0;
    }
},

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/702581.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ES架构原理分析

节点职责 节点按照职责可以分为&#xff1a; master节点数据节点协调节点 节点类型可以进行单独配置。默认情况下&#xff0c;集群不会对节点角色进行划分&#xff0c;所有节点都是平等的&#xff0c;可以担任所有的职责。但是在生产环境中需要对这些节点的角色进行最优划分…

HAL库记录-SDIO外设SD卡

正点原子--阿波罗开发板STM32F429IGT6 1.STM32CubeMX配置 2.生成的代码 /*** Enable DMA controller clock*/ void MX_DMA_Init(void) {/* DMA controller clock enable */__HAL_RCC_DMA2_CLK_ENABLE();/* DMA interrupt init *//* DMA2_Stream3_IRQn interrupt configuratio…

CSS差缺补漏之《高频面试题----如何使元素水平垂直居中?》

面试中经常会被问到如何使元素水平垂直居中&#xff0c;有哪些方法可以做到&#xff1f; 针对此问题&#xff0c;特意总结如下~ 方法一&#xff1a; 定位&#xff08;主要是值子绝父相&#xff09;与margin负值配合----依赖于子元素宽/高 (使用绝对定位或固定定位后&#xff0c…

GitLab无法提交大文件的问题

GitLab无法提交大文件的问题 问题描述 GitLab 当提交大文件时遇到如下报错 MYOPS001MYOPS001 MINGW64 /e/work/GitLab/system-deploy (main) $ git push Enumerating objects: 91, done. Counting objects: 100% (91/91), done. Delta compression using up to 16 threads C…

ARM-异常中断处理概述(五)

文章目录 控制程序执行流程ARM 体系中异常中断种类 控制程序执行流程 在 ARM 体系中通常有以下 3 种方式控制程序的执行流程&#xff1a; 在正常程序中执行过程中&#xff0c;每执行一条 ARM 指令&#xff0c;程序计数寄存器 PC 的值加 4 个字节&#xff1b;每执行一条 Thumb…

Python车道线识别

最近找了一款车道线识别的代码&#xff0c;可以准确识别出车道线&#xff0c;里面的视频路径可以切换为自己的视频&#xff0c;现在我以自带的视频数据展示效果 图片中可以准确识别车的车道线&#xff1a; 下面给出一部分源代码&#xff1a; import cv2 import numpy as np i…

汽车统一bootloaderv2.0版本 翻译

统一bootloader系统 统一bootloader范围 下图展示了PC通过适配器与ECU连接。高亮公布部分是ECU和PC共同的。所有平台都是一样的。 统一bootloader关键特征 UDS(ISO14229)TP(ISO1765-2/CAN,ISO17987-2/LIN)Flash驱动包括共同的要求从主机下载Flash驱动bootloader检测APP完整…

元宇宙赋能数字文创 | 蓝海创意云受邀发表瑶海区文化创意产业数字化高峰论坛主题演讲

2023年6月29日&#xff0c;在合肥市文化旅游局的指导下&#xff0c;由中共合肥市瑶海区委员会和合肥市瑶海区人民政府主办的“2023瑶海文化创意产业数字化高峰论坛”于合肥市长江180艺术街区召开&#xff0c;本次论坛以“传承创新&#xff0c;数字引领”为主题&#xff0c;探索…

uniapp项目 完成一个点击 展开 收起的效果

需求是: 即将解锁勋章模块 默认只展示三条数据,当数据大于3条时显示展开,点击展开显示全部数据,展开按钮变为收起,点击收起就只展示三条数据,且收起按钮变为展开. 小于或等于3条时显示所有数据,且不显示展开收起, <view class"unlock"><view style&quo…

Modbus协议学习方法

在刚开始接触modbus协议的时候&#xff0c;很容易被里面的各种功能码搞晕&#xff0c;同时在编写程序的时候也容易搞不清楚每一位数据代表的含义。如果在学习的过程中有实际的发送和接收数据的例子话&#xff0c;那么理解modbus协议就会更容易一些。   下面我将自己借助软件学…

3.0C++虚函数

C 虚函数 C的虚函数是一种特殊的成员函数&#xff0c;可以在派生类中被重写。 虚函数的作用是实现多态性&#xff0c;当我们使用基类指针或引用来调用虚函数时&#xff0c;程序会根据实际的对象类型来调用相应的派生类函数。 我们可以将一个成员函数声明为虚函数&#xff0c…

C++primer(第五版)第六章(函数)

6.1函数基础 函数可以理解成是可以循环使用的代码块.函数的定义通常包含以下部分:返回类型,函数名称,参数列表,函数体. //以下是一个返回值为int类型,有两个参数的函数的定义 int add(int a,int b){return ab; }我们用调用运算符( )来执行函数,在运算符内传入参数.调用时会打…

如何确保大模型追求“正确”的目标?丨AI安全与对齐圆桌回顾

导读 在智源大会「AI 安全与对齐」论坛上&#xff0c;与会嘉宾针对目前人们关心的 AI 安全控制标准、多智能体强化学习环境下的安全、开源对 AI 安全的影响、对智能涌现安全的思考等问题展开了讨论。 能力越大&#xff0c;责任越大。 嘉宾名单 谢旻希丨主持人&#xff0c;安远A…

高压线路距离保护程序逻辑原理(一)

为了保证高压线路输电的稳定性和可靠性&#xff0c;通常要求高压电网构成多侧电源的环形电网。在这种电网中简单的电压电流保护往往不能满足保护的基本要求&#xff0c;例如方向电流保护往往不能保证有选择性地切除故障。为此&#xff0c;在多侧电源的环形电网的线路上配置了选…

使用Nexus搭建Maven私有库实战

本篇快速演示如何搭建和使用Nexus本地库&#xff0c; 关于Nexus 的基本使用参考&#xff1a; Nexus搭建Maven私有库介绍 实战场景 本篇的实际场景是&#xff1a; 本地开发机器可以连接外部网络测试或正式部署环境只能连接内网项目使用了内部开发的组件库 在搭建搭建Maven私…

如何一次解决两大难题,不用写注释,也不会被他人吐槽没有注释呢?

如何一次解决两大难题&#xff0c;不用写注释&#xff0c;也不会被他人吐槽没有注释呢&#xff1f;&#xfeff; 导读为什么要减少代码中的注释量呢&#xff1f;一、无用型的注释二、絮絮叨叨的注释三、代替代码分层的注释四、不知所云的注释 参考&#xff1a;阿里云开发者社区…

【vs2022】解决 “对程序集签名是出错 - 拒绝访问 ”

背景 拿到一个工程&#xff0c;编译时报错&#xff1a;“对程序集签名是出错 - 拒绝访问” 解决方法 ”C:\ProgramData\Microsoft\Crypto\RSA”目录下面&#xff0c;找到【MachineKeys】文件夹。 右键【MachineKeys】文件夹&#xff0c;在安全属性里面&#xff0c;将当前win…

DETR系列:RT-DETR(一) 论文解析

论文&#xff1a;《DETRs Beat YOLOs on Real-time Object Detection》 2023.4 DETRs Beat YOLOs on Real-time Object Detection&#xff1a;https://arxiv.org/pdf/2304.08069.pdf 源码地址&#xff1a;https://github.com/PaddlePaddle/PaddleDetection/tree/develop/conf…

江西五十铃汽车PMO经理苏建受邀为第十二届PMO大会演讲嘉宾

江西五十铃汽车有限公司PMO经理苏建先生受邀为由PMO评论主办的2023第十二届中国PMO大会演讲嘉宾&#xff0c;演讲议题&#xff1a;PMO全链路建设促进组织变革——传统汽车行业0-1PMO最佳实践探索。大会将于8月12-13日在北京举办&#xff0c;敬请关注&#xff01; 议题简要&…

LangChain:LLM应用程序开发(上)——Models、Prompt、Parsers、Memory、Chains

文章目录 一、Models、Prompt、Parsers1.1 环境配置&#xff08;导入openai&#xff09;1.2 辅助函数&#xff08;Chat API : OpenAI&#xff09;1.3 使用OpenAI API进行文本翻译1.4使用LangChain进行文本翻译1.5 使用LangChain解析LLM的JSON输出1.5.1 LangChain输出为string格…