JS判断两个table数据是否完全相等(判断两个数组对象是否完全相等)
需求
现有的table为tableA
,有多个要做对比的table为一个数组 CompareArray
涉及到的问题
- 外层是数组,但是内部数据都是对象,对象属性名的排序不一样
- 外层数组也涉及到 顺序不一样的问题
思路
-
对
compareArray
做长度筛选filter
得到 同长度的table,为一个新数组,sameLengthArray
-
对
tableA
以属性名称做排序(这里应该是以属性名称的英文字母做排序) -
对
sameLengthArray
做filter遍历, 对遍历的每一项sItem
,先做一个以属性名称做排序 -
tableA
做filter遍历,判断当前项e
在sItem
中是否找得到 【用字符串来判断】JSON.stringify(sItem).includes(JSON.stringify(e))
5.如果两个table一样,那么步骤4
filter出来的长度
就应该和tableA
的长度一样
Code
// 先筛选出条件长度相同的项const sameLengthArray = compareArray.filter(e => e.length === tableA.length)if (sameLengthArray && sameLengthArray.length > 0) {// 以属性名称做排序tableA.forEach((e, index) => {tableA[index] = JSON.parse(JSON.stringify(objKeySort(e)))})const resultRecord = sameLengthArray.filter(sItem => {// 以属性名称做排序sItem.forEach((e, index) => {sItem[index] = JSON.parse(JSON.stringify(objKeySort(e)))})// 如果当前和这个是一样的,那么filter出来的数组应该和当前数组长度一致const hasIndex = tableA.filter(e =>JSON.stringify(sItem).includes(JSON.stringify(e)))return hasIndex && hasIndex.length === tableA.length})if (resultRecord && resultRecord.length > 0) {console.log("存在数据相同的table")} else {console.log("没有相同的table")}} else {console.log("没有相同的table")}//**********************************
// 属性排序方法是额外的
export function objKeySort(obj) {//排序的函数var newkey = Object.keys(obj).sort();//先用Object内置类的keys方法获取要排序对象的属性名,再利用Array原型上的sort方法对获取的属性名进行排序,newkey是一个数组var newObj = {};//创建一个新的对象,用于存放排好序的键值对for (var i = 0; i < newkey.length; i++) {//遍历newkey数组newObj[newkey[i]] = obj[newkey[i]];//向新创建的对象中按照排好的顺序依次增加键值对}return newObj;//返回排好序的新对象
}
相关文章:
![](https://www.ngui.cc/images/no-images.jpg)
JS判断两个table数据是否完全相等(判断两个数组对象是否完全相等)
需求 现有的table为tableA,有多个要做对比的table为一个数组 CompareArray 涉及到的问题 外层是数组,但是内部数据都是对象,对象属性名的排序不一样外层数组也涉及到 顺序不一样的问题 思路 对compareArray做长度筛选 filter 得到 同长度…...
![](https://img-blog.csdnimg.cn/img_convert/8202fa5fdc0037e732e824ff24ca5f39.png)
关于小程序,你想知道的这些
近年来,各大平台纷纷上架小程序,迎来了小程序的爆发式增长。今天就来跟大家简单分享一下小程序基本的运行机制和安全机制。 小程序的由来 在小程序没有出来之前,最初微信WebView逐渐成为移动web重要入口,微信发布了一整套网页开…...
![](https://www.ngui.cc/images/no-images.jpg)
WuThreat身份安全云-TVD每日漏洞情报-2023-02-13
漏洞名称:THORSTEN PHPMYFAQ 跨站点脚本 漏洞级别:高危 漏洞编号:CVE-2023-0791 相关涉及:THORSTEN PHPMYFAQ 3.1.10 漏洞状态:POC 参考链接:https://tvd.wuthreat.com/#/listDetail?TVD_IDTVD-2023-03506 漏洞名称:TENDA AC23 越界写入 漏洞级别:高危 漏洞编号:CVE-2023-078…...
![](https://img-blog.csdnimg.cn/e29ff6cfe60f433eb8a206f6be5e3aef.png)
【Linux】软件安装(三分钟教会你如何在linux下安装软件)
🔥🔥 欢迎来到小林的博客!! 🛰️博客主页:✈️小林爱敲代码 🛰️博客专栏:✈️Linux之路 🛰️社区:✈️进步学堂 目录&…...
![](https://www.ngui.cc/images/no-images.jpg)
Fluent Python 笔记 第 10 章 序列的修改、散列和切片
本章将以第 9 章定义的二维向量 Vector2d 类为基础,向前迈出一大步,定义表示多维向量的 Vector 类。这个类的行为与 Python 中标准的不可变扁平序列一样。 10.3 协议和鸭子类型 在 Python 中创建功能完善的序列类型无需使用继承,只需实现符…...
![](https://img-blog.csdnimg.cn/img_convert/ab4e5ae18388d48026827bd741033fdb.png)
在中国程序员工作是青春饭吗?
上个月公司告诉我毕业了。 我打开boss直聘,一溜溜的外包公司和我打招呼。 我寻思我说不定啥时候就离开深圳了,外包不外包也无所谓钱到位就行。(大公司学历不够格也进不去) 结果华为、平安的外包告诉我,不好意思呀&a…...
![](https://img-blog.csdnimg.cn/0a2c3fb4ac9948988c0a91dd75d6b2c8.jpeg#pic_center)
Linux tcpdump
tcpdump - 转储网络上的数据流 是不是感觉很懵?全方位描述tcpdump: 通俗:tcpdump是一个抓包工具,用于抓取网络中传输的数据包形象:tcpdump如同国家海关,凡是入境和出境的货物,海关都要抽样检查࿰…...
![](https://img-blog.csdnimg.cn/3c104788ca8441198a17cf0c11c6337c.png)
redis知识汇总(部署、高可用、集群)
文章目录一、redis知识汇总什么是redisredis的优缺点:为什么要用redis做缓存redis为什么这么快什么是持久化redis持久化机制是什么?各自优缺点?AOF和RDB怎么选择redis持久化数据和缓存怎么做扩容什么是事务redis事务的概念ACID概念主从复制re…...
![](https://img-blog.csdnimg.cn/img_convert/66843d72ec86b4dcf161babfd2aab976.png)
【手写 Vuex 源码】第十篇 - Vuex 命名空间的实现
一,前言 上一篇,主要介绍了 Vuex 响应式数据和缓存的实现,主要涉及以下几个点: Vuex 的响应式实现原理;响应式核心方法 resetStoreVM;commit 和 dispatch 的处理; 本篇,继续介绍 …...
![](https://img-blog.csdnimg.cn/47325515693541728df1ff93aa14683f.png)
面试腾讯测试岗后感想,真的很后悔这5年一直都干的是基础测试....
前两天,我的一个朋友去大厂面试,跟我聊天时说:输的很彻底… 我问她:什么情况?她说:很后悔这5年来一直都干的是功能测试… 相信许多测试人也跟我朋友一样,从事了软件测试很多年,却依…...
![](https://www.ngui.cc/images/no-images.jpg)
知识图谱 方法、实践与应用 王昊奋 读书笔记(下)
最近读了这本书,在思路上很有启发,对知识图谱有了初步的认识,以下是原书后半部分的内容,可以购买实体书获取更多内容。 知识图谱推理 结合已有规则,推出新的事实,例如持有股份就能控制一家公司࿰…...
![](https://img-blog.csdnimg.cn/04bf1b4f49944e11bcc0aa8ffbcc2845.png)
vue实现打印浏览器页面功能(两种方法)
推荐使用方法二 方法一:通过npm 安装插件 1,安装 npm install vue-print-nb --save 2,引入 安装好以后在main.js文件中引入 import Print from vue-print-nbVue.use(Print); //注册 3,现在就可以使用了 div id"printTest…...
![](https://img-blog.csdnimg.cn/img_convert/142733bbdfe0f660746fa7074324dcb0.png)
【VictoriaMetrics】VictoriaMetrics单机版批量和单条数据写入(Prometheus格式)
VictoriaMetrics单机版支持以Prometheus格式的数据写入,写入支持单条数据写入以及多条数据写入,下面操作演示下如何使用 1、首先需要启动VictoriaMetrics单机版服务 2、使用postman插入单机版VictoriaMetrics,以当前时间插入数据 地址为 http://victoriaMetricsIP:8428/api…...
![](https://img-blog.csdnimg.cn/img_convert/5f9573fbdfaf7380ec1c2fc1d36ed6b5.png)
【青训营】分布式定时任务简述
这是我参与「第五届青训营 」伴学笔记创作活动的第 13 天 分布式定时任务简述 定义 定时任务是指系统为了自动完成特定任务,实时、延时、周期性完成任务调度的过程。分布式定时任务是把分散的、可靠性差的定时任务纳入统一平台,并且实现集群管理调度和…...
![](https://img-blog.csdnimg.cn/b225d086741b48658083a5e05ad3382a.png)
golang语言本身设计点总结
本文参考 1.golang的内存管理分配 golang的内存分配仿造Google公司的内存分配方法TCmalloc算法;她会把将内存请求分为两类,大对象请求和小对象请求,大对象为>32K的对象。 在了解golang的内存分配之前要知道什么事虚拟内存,虚拟内存是把磁盘作为全局…...
![](https://img-blog.csdnimg.cn/465eb0f461144866b78553e375ab8124.png)
PTA L1-046 整除光棍(详解)
前言:内容包括四大模块:题目,代码实现,大致思路,代码解读 题目: 这里所谓的“光棍”,并不是指单身汪啦~ 说的是全部由1组成的数字,比如1、11、111、1111等。传说任何一个光棍都能被…...
![](https://img-blog.csdnimg.cn/59bd150a208f490a9bae96b7e544abbc.png)
将小程序代码转成uni-app代码
最近因为公司项目原因需要将小程序的项目转换成uni—app的项目,所以总结了以下几点: 首先你可以先到uni-app的官网简单看一下对它的介绍,本次文章的介绍是针对简单的微信小程序来进行的转化。 在这之前我们来看一下目录对比 下面就来介绍一下…...
![](https://i0.hdslb.com/bfs/face/0b535f3a82e731c68ba4148002f121c3128a9662.jpg)
C语言在游戏中播放音乐
使用 mciSendString 播放音乐 mciSendString 支持 mp3、wma、wav、mid 等多种媒体格式,使用非常简单。这里做一个简单的范例,用 mciSendString 函数播放 MP3 格式的音乐,代码如下: // 编译该范例前,请把 music.mp3 放…...
![](https://img-blog.csdnimg.cn/img_convert/3e49b9596a451fea55e8ed6af5fb3b8c.png)
机器学习算法:随机森林
在经典机器学习中,随机森林一直是一种灵丹妙药类型的模型。 该模型很棒有几个原因: 与许多其他算法相比,需要较少的数据预处理,因此易于设置充当分类或回归模型不太容易过度拟合可以轻松计算特征重要性在本文[1]中,我想…...
![](https://img-blog.csdnimg.cn/img_convert/c6051cbb3ff4c2e7b51a8b2a4067a5d3.png)
如何做好多项目全生命周期的资源调配,提升资源利用效率?【橙子】
随着产品研发中心各团队承接的研发项目数量和规模日趋增加,人均产值和利润目标逐步提升,人均承接的项目数量也逐渐增加,目前缺乏合理的研发资源管理方案,存在多项目研发过程中资源冲突及部分项目研发人员忙闲不均等现象࿰…...
![](https://img-blog.csdnimg.cn/img_convert/718de0977c6e7cdf1e649c4e509ef544.jpeg)
JVM - 内存分配
目录 JVM的简化架构和运行时数据区 JVM的简化架构 运行时数据区 PC寄存器 Java栈 Java堆 方法区 运行时常量池 本地方法栈 栈、堆、方法区交互关系 Java堆内存模型和分配 Java堆内存概述 Java堆的结构 对象的内存布局 对象的访问定位 Trace跟踪和Java堆的参数配…...
![](https://img-blog.csdnimg.cn/b3f5beb7c1174315aa55cb8d22303887.png)
【知识图谱论文】Bi-Link:通过转换器和提示的对比学习桥接来自文本的归纳链接预测
文献题目:Bi-Link: Bridging Inductive Link Predictions from Text via Contrastive Learning of Transformers and Prompts发表期刊:WWW2023代码: https://anonymous.4open.science/r/Bi-Link-2277/. 摘要 归纳知识图的完成需要模型来理解…...
![](https://img-blog.csdnimg.cn/d5682268e7f64b1592957cff52d42562.png)
jieba+wordcloud 词云分析 202302 QCon 议题 TOP 关键词
效果图 步骤 (1)依赖 python 库 pip install jieba wordcloud数据 概览 $ head -n 5 input.txt 中国软件技术发展洞察和趋势预测报告 2023 QCon 大会内容策划思路 FinOps:从概念到落地 开源芯片的发展现状、机遇和未来 乐观者前行࿰…...
![](https://img-blog.csdnimg.cn/img_convert/eca4e2991d15032fadb62557e7318086.png)
包管理工具-npm-npx-yarn-cnpm
代码共享方案 在我们通过模块化的方式将代码划分成一个个小的结构后,在以后的开发中我们就可以通过模块化的方式来封装自己的代码,并且封装成一个工具,这个工具我们可以让同事通过导入的方式来使用,甚至你可以分享给世界各地的程…...
![](https://img-blog.csdnimg.cn/9ede58dbc57f4851840b715450809732.png)
go gin学习记录1
环境: MAC M1,Go 1.17.2,GoLand 默认执行指令的终端,如果没有特别说明,指的都是goland->Terminal 创建项目 Goland中新建项目,在$GOPATH/src/目录下建立t_gin项目。 进入项目,在goland的T…...
![](https://img-blog.csdnimg.cn/img_convert/f1b9263c56aa4d7a8393e7dc22329a5f.png)
Docker常用命令
1:帮助命令docker versiondocker infodocker --help2:镜像命令docker images(列出本地主机上的镜像)各个选项说明:docker imagesREPOSITORY:表示镜docker images像的仓库源TAG:镜像的标签IMAGE IDÿ…...
![](https://img-blog.csdnimg.cn/6f643863c959403cb06cbac7ad342c92.png)
论文写作——公式编辑器、latex表格、颜色搭配器
1、公式编辑器(网页版mathtype可用于latex公式编辑): MathType demo - For DevelopersLive demonstration about the features of Mathtype which allows edition equations and formulas (PNG, flash, SVG, PDF, EPS), based on MathML and compatible with LaTeX.https:/…...
![](https://img-blog.csdnimg.cn/03cb8a479210419ab2770d16ff70bf22.png)
MySQL数据库12——视图(VIEW)
视图概念 视图是一个虚拟表,称其为虚拟表的原因是:视图内的数据并不属于视图本身,而属于创建视图时用到的基本表。可以认为,视图是一个表中的数据经过某种筛选后的显示方式;或者多个表中的数据经过连接筛选后的显示方…...
![](https://img-blog.csdnimg.cn/154bf42ef23f486cb0875b1a850ef3ef.png)
第四代英特尔至强重磅发布,芯片进入下半场:软硬加速、绿色可持续
编辑 | 宋慧 出品 | CSDN 云计算 2023 年的第二周,英特尔重磅发布其企业级芯片领域重要的产品——第四代英特尔 至强 可扩展处理器。作为数据中心处理器当之无愧的王牌产品,迄今为止,英特尔已经向全球客户交付了超8500万颗至强可扩展处理器…...
![](https://www.ngui.cc/images/no-images.jpg)
c++-运算符函数与运算符重载
目录概述例子注意问题概述 运算符重载是函数一个特殊情况,重载的运算符视为特殊的函数,称为运算符函数。 编译系统能依据使用运算符的不同环境,即参数(操作数)的数量或类型的差异,区分同一运算符的不同含义…...
![](https://img-blog.csdnimg.cn/2020060921134170.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2h1X3poaV9jaGFv,size_16,color_FFFFFF,t_70#pic_center)
网络培训资格证书如何获得/重庆seo按天收费
Oracle第二天一.视图[应用]二.索引[应用]三.pl/sql 基本语法[了解]1.pl/sql 程序语法2.常量和变量定义3. if 分支4.LOOP 循环语句5.游标 Cursor四.存储过程[理解]五.存储函数[理解]六.触发器[理解]七.Java 程序调用存储过程[应用]1.java 连接 oracle 的 jar 包2.实现…...
![](https://img-blog.csdnimg.cn/img_convert/9983481b8792494870291ca8bb1d02bb.png)
站酷官网/seo设置是什么
前言 一次偶然,从朋友那里得到一份“java高分面试指南”,里面涵盖了25个分类的面试题以及详细的解析:JavaOOP、Java集合/泛型、Java中的IO与NIO、Java反射、Java序列化、Java注解、多线程&并发、JVM、Mysql、Redis、Memcached、MongoDB、…...
![](/images/no-images.jpg)
cm域名网站/成人馆店精准引流怎么推广
某培训机构的课程表,不想去培训的,可以按照这个自学。 1 第一阶段JAVASCRIPT高级 1 1 JavaScript高级 1 1 1 call、apply、bind、new等原理解析1 1 2 原型链深入1 1 3 闭包深入1 1 4 执行上下文和作用域链1 1 5 作用域链1 2 ES6深入学习 1 2 1 常量1 2 2…...
![](/images/no-images.jpg)
dw怎么用div css做网站6/百度指数属于行业趋势及人群
企业级(299$)的开发者账号不能上传到App Store,通过一些分发平台比如说firm、蒲公英等又有一些下载限制,如果我们放到"自己"服务器来进行下载会是一种很好的选择,也是苹果推荐的方式。以无线方式安装企业内部应用(苹果官方文档)实现…...
![](https://img-blog.csdnimg.cn/img_convert/ffb26747c656c46b250195e81d6dccd9.png)
网站开发项目介绍/关键词优化百家号
项目介绍和数据采集 1.了解行业背景知识 个股、指数、板块,涨跌幅、振幅,换手率,成交占比 成交时间:9:30-11:30 13:00-15:00 2.介绍今日证券项目 1.项目介绍 基于flink实时流计算的,金融证券项目,实时大屏展示,预警模块和离线模块的处理。 2. UI产品原型 首页 涨…...
![](/images/no-images.jpg)
政府网站集约化建设试点/seo是什么服务器
写在前面 业务逻辑是这样的,需要导出一个app的话题,并需要把该话题下帖子的附件导出,然后需求想修改成人员的名称.jpg的格式。所以就出现了中文乱码的问题。在本地没问题,但发布到服务器上面就出问题,每次打包下载下面…...