javascript 中数组对象操作方法

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

javascript 复制代码
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,它不会修改原数组。

javascript 复制代码
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:组合使用可实现在两个数组对象中找到相同的元素

javascript 复制代码
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:组合使用也可实现在两个数组对象中找到不相同的元素

javascript 复制代码
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对象高效率查找,更适合大量数据使用

javascript 复制代码
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';

javascript 复制代码
  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';

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

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

javascript 复制代码
 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)

​
相关推荐
LYFlied1 分钟前
AI时代下的规范驱动开发:重塑前端工程实践
前端·人工智能·驱动开发·ai编程
CodeCraft Studio14 分钟前
JavaScript图表库 DHTMLX Diagram 6.1 重磅发布:全新PERT模式上线,项目可视化能力再升级!
开发语言·javascript·ecmascript·dhtmlx·图表开发·diagram·javascript图表库
汉得数字平台32 分钟前
汉得H-AI飞码——前端编码助手V1.1.2正式发布:融业务知识,提开发效能
前端·人工智能·智能编码
前端小万33 分钟前
Jenkins 打包崩了?罪魁是 package.json 里的 ^
前端·jenkins
编程小白gogogo33 分钟前
苍穹外卖前端环境搭建
前端
shuaijie051834 分钟前
当表格数据量过大的时候,如何使用不分页进行展示
javascript·vue.js·ecmascript
光影少年36 分钟前
web端安全问题有哪些?
前端·安全
行走的陀螺仪44 分钟前
Vite & Webpack 插件/Loader 封装完全指南
前端·webpack·node.js·vite·前端工程化·打包构建
1024肥宅1 小时前
浏览器网络请求 API:全面解析与高级封装(1)
前端·websocket·axios
小费的部落1 小时前
Excel 在Sheet3中 匹配Sheet1的A列和Sheet2的A列并处理空内容
java·前端·excel