element-table实现一个员工两个月的工资条数据对比

2023-11-04 05:20

本文主要是介绍element-table实现一个员工两个月的工资条数据对比,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现一个表格里面,单个员工的本月数据和上月数据对比,比如本月薪资发放与上月薪资发放数据对比,将不同的项标记,只标记上月不同的,标记成蓝色背景,如果是本月入职的,没有上月的记录,就没有对比数据,表格里面标记员工工号这一单元格,标记成黄色。


// 1,首先到后端拿到数据
const tableData = this.table.data
// 是否是刚入职的数据或者导入的数据
// 拿到dataMap,里面就是员工对应的几条数据,1条就是新入职的,
// 2条就是本月和上月的
// firstEntry 是只有一条数据的刚入职的只有一个月薪资的员工
const dataMap = {}
tableData.forEach((item) => {if (dataMap[item.employeeId]) {dataMap[item.employeeId].push(item)const [data1] = dataMap[item.employeeId]data1.firstEntry = false// data2.firstEntry = falsethis.compareData(dataMap[item.employeeId])} else {dataMap[item.employeeId] = [item]item.firstEntry = true}
}
// 生成的数据是 {1000082: [{}, {}] }/* 或者 */
// 对比之前也可以这样处理
// 1.取出数据里面相同employeeId出现的次数
let countedEmployeeIds = tableData.reduce((obj, item) => {if (item['employeeId'] in obj) {obj[`${item.employeeId}`]++} else {obj[`${item.employeeId}`] = 1}return obj
}, {})
// countedEmployeeIds: {1000082: 2} 或者 countedEmployeeIds: {1000031: 1}
// 2.标记刚入职的this.table.data.forEach(item => {item.firstEntry = countedEmployeeIds[item.employeeId] <= 1})// 3.取出对比的员工的数据
let compareData = []
let sameData = []
tableData.map(item => {if (sameData.length >= 2) {sameData = []}if (countedEmployeeIds[item.employeeId] > 1) {sameData.push(item)}if (sameData.length === 2) {compareData.push(sameData)}
})
// 4.用该数据去对比
compareData.forEach(item => {this.compareData(item)
}) 

// 用differentOptions存下对比员工不同的项
// differentOptions: {}
compareData (item) {this.differentOptions[`${item[0].employeeId}`] = []Object.keys(item[0]).forEach(key => {let value0 = item[0][key]let value1 = item[1][key]if (value0 !== value1) {if (Number(key)) {this.differentOptions[`${item[0].employeeId}`].push(key)}}})
}
// 给单元格添加不同背景
// :cell-class-name="setCellClassName"
setCellClassName ({ row, column, rowIndex, columnIndex }) {
// console.log('@@@', this.differentOptions)
if (column.property === 'employeeCode') {if (row.firstEntry) {return 'first-entry'} else {return ''}
} else {if (rowIndex % 2 === 0) {if (this.differentOptions[row.employeeId]?.some(prop => prop === column.property)) {return 'different-option'} else {return ''}}
}
// 样式设置 scss scoped
/deep/.first-entry {background-color: #2AF598 !important;background-clip: content-box !important;
}
/deep/.different-option {background-color: #00b0f0 !important;background-clip: content-box !important;
}

效果如图:
在这里插入图片描述
在这里插入图片描述

这篇关于element-table实现一个员工两个月的工资条数据对比的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/343499

相关文章

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统