当前位置: 首页 > news >正文

javascript 中数组对象操作方法

一、Filter方法:该方法会对原数组过滤并返回新数组,它不会改变原数组

let array2=[{id:'songxiaofeng',name:'宋晓锋'},{id:'xieyongqiang',name:'谢永强'},{id:'zhaoyutian',name:'赵玉田'},{id:'wangtianlai',name:'王天来'},{id:'zhaosi',name:'赵四'}]let array=array2.filter(i=>i.id=="zhaosi");console.log('array',array);

二、Some方法:该方法会遍历数组元素,找到符合条件的元素返回true,否则返回false,它不会修改原数组。

let array2=[{id:'songxiaofeng',name:'宋晓锋'},{id:'xieyongqiang',name:'谢永强'},{id:'zhaoyutian',name:'赵玉田'},{id:'wangtianlai',name:'王天来'},{id:'zhaosi',name:'赵四'}]let bool=array2.some(i=>i.id=="zhaosi");console.log('bool',bool);

 三、Filter和Some:组合使用可实现在两个数组对象中找到相同的元素

let array1=[{id:'pichangshan',name:'皮常山'},{id:'xieguangkun',name:'谢广坤'},{id:'wanglaoqi',name:'王老七'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}
]
let array2=[{id:'songxiaofeng',name:'宋晓锋'},{id:'xieyongqiang',name:'谢永强'},{id:'zhaoyutian',name:'赵玉田'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}
]let array=array1.filter(i=>array2.some(item=>i.id==item.id));console.log('array',array);

 四、Filter和Some:组合使用也可实现在两个数组对象中找到不相同的元素

let array1=[{id:'pichangshan',name:'皮常山'},{id:'xieguangkun',name:'谢广坤'},{id:'wanglaoqi',name:'王老七'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}
]
let array2=[{id:'songxiaofeng',name:'宋晓锋'},{id:'xieyongqiang',name:'谢永强'},{id:'zhaoyutian',name:'赵玉田'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}
]let array=array1.filter(i=>!array2.some(item=>i.id==item.id));let arrays=array2.filter(i=>!array1.some(item=>i.id==item.id));console.log('array',array);console.log('arrays',arrays);

 五、Map:使用Map对象高效率查找,更适合大量数据使用

let array1=[{id:'pichangshan',name:'皮常山'},{id:'xieguangkun',name:'谢广坤'},{id:'wanglaoqi',name:'王老七'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}]let array2=[{id:'songxiaofeng',name:'宋晓锋'},{id:'xieyongqiang',name:'谢永强'},{id:'zhaoyutian',name:'赵玉田'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}]let map=new Map(array1.map(item=>[item.id,item]));console.log('map',map);let arrays=array2.filter(i=>map.has(i.id));console.log('arrays',arrays);

六:unionBy合并去重,属于 'lodash'下方法‌,需要安装和引入

import {unionBy,isEqual} from 'lodash';

  let array1=[{id:'pichangshan',name:'皮常山'},{id:'xieguangkun',name:'谢广坤'},{id:'wanglaoqi',name:'王老七'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}]let array2=[{id:'songxiaofeng',name:'宋晓锋'},{id:'xieyongqiang',name:'谢永强'},{id:'zhaoyutian',name:'赵玉田'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}]let array=unionBy(array2, array1, 'id');console.log('array',array)

七:isEqual判断两个对象是否相同,属于 'lodash'下方法‌,需要安装和引入

import {unionBy,isEqual} from 'lodash';

    let params1={id:'zhaosi',name:'赵四'};let params2={id:'liuneng',name:'刘能'};let bool=isEqual(params2, params1);console.log('bool',bool)

也适用于数组对象比较是否相同

 let array1=[{id:'pichangshan',name:'皮常山'},{id:'xieguangkun',name:'谢广坤'},{id:'wanglaoqi',name:'王老七'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}]let array2=[{id:'pichangshan',name:'皮常山'},{id:'xieguangkun',name:'谢广坤'},{id:'wanglaoqi',name:'王老七'},{id:'liuneng',name:'刘能'},{id:'zhaosi',name:'赵四'}]let bool=isEqual(array1, array2);console.log('bool',bool)​

http://www.lryc.cn/news/592025.html

相关文章:

  • AE PDW2200电源射频手侧使用安装说明含电路图
  • 自学力扣:最长连续序列
  • CSS样式中的布局、字体、响应式布局
  • AI大模型打造金融智能信审助手04.七大金融监管相关政策
  • 【Oracle】centos7离线静默安装oracle11g(p13390677_112040)
  • 智象科技赋能金融、证券行业 IT 运维
  • PostgreSQL 16 Administration Cookbook 读书笔记:第7章 Database Administration
  • 【git仓库搭建笔记】
  • Oracle 19C 后台主要进程的功能解析
  • CertiK创始人顾荣辉出席上海Conflux大会,聚焦Web3全球化中的安全与合规路径
  • 赛思SLIC芯片、语音芯片原厂 赛思SLIC语音芯片ASX630:国产强“芯”赋能FTTR全光网络​
  • Docker Swarm 集群使用记录
  • 基于LiteNetLib的Server/Client Demo
  • 算法训练营day24 回溯算法③ 93.复原IP地址 、78.子集、 90.子集II
  • 零基础入门:用C++从零实现TCP Socket网络小工具
  • 人脸检测算法——SCRFD
  • Ubuntu系统下快速体验iperf3工具(网络性能测试)
  • 2G和3G网络关闭/退网状态(截止2025年7月)
  • Python技术题1
  • 【RK3576】【Android14】开发环境搭建
  • 基于现代R语言【Tidyverse、Tidymodel】的机器学习方法与案例分析
  • 用 React-Three-Fiber 实现雪花下落与堆积效果:从零开始的 3D 雪景模拟
  • 前端迟迟收不到响应,登录拦截器踩坑!
  • 小结:Spring MVC 的 XML 的经典配置方式
  • ASP.NET Core Web API 内存缓存(IMemoryCache)入门指南
  • untiy之导入插件(文件方式,适用于git克隆失败)
  • Instagram千号矩阵:亚矩阵云手机破解设备指纹检测的终极方案
  • 【.net core】支持通过属性名称索引的泛型包装类
  • 五国联动!德法意西荷 ASIN 同步上架成泛欧计划硬性门槛
  • 构建智能客服Agent:从需求分析到生产部署