处理数组相关方法(持续更新)

1.比较一个数组是否包含另一个数组a包含b(返回true包含,false不包含)(注:不能含有重复元素的数组

const isContained = (a, b) => {
  if (!(a instanceof Array) || !(b instanceof Array)) return false;
  // 方法1
  // let res = b.filter(v=>{
  // 	return a.indexOf(v) != -1
  // })
  // return res.length == b.length;
  // 方法二
  return b.every((val) => a.includes(val));
}

中间含有两种方法,哪种好理解用哪种

2..比较一个数组是否完全匹配另一个数组(true相等,false不相等)(注:不能含有重复元素的数组

  const arrIsSame = (a, b)=> {
    if (!(a instanceof Array) || !(b instanceof Array)) return false;
    let res =[]
    if(a.length == b.length){
        res = b.filter(v=>{
        return a.indexOf(v) != -1
      })
    } 
    return res.length == b.length;
  },
const arrIsSame = (a, b) => {
  if (a.length !== b.length) {
      return false
  }
  return a.every(item => b.indexOf(item) > -1)
}

针对上面不能含有重复元素的数组进行了修改

完全相等调整如下:

 arrIsSame (a1, a2){
        if (!(a1 instanceof Array) || !(a2 instanceof Array)) return false;
        // 不改变原数组
        let a = JSON.parse(JSON.stringify(a1))
        let b = JSON.parse(JSON.stringify(a2))
        a.sort()
        b.sort()
        return a.join() == b.join()
    },

前端实现返回数组模糊查询

    fuzzyQuery(list, keyWord) {
        var reg =  new RegExp(keyWord);
        var arr = [];
        for (var i = 0; i < list.length; i++) {
          if (reg.test(list[i].name)) {
            arr.push(list[i]);
          }
        }
        return arr;
      },

回答: JavaScript提供了许多数组API方法来方便地操作数组。其中一些常用的方法包括: 1. filter()方法:该方法创建一个新数组,其中包含满足指定条件的所有元素。可以使用filter()方法来过滤数组中的元素。在给定的代码示例中,使用了一个for循环来过滤出名字中包含"John"的员工,并将它们添加到一个新的数组中。\[1\] 2. forEach()方法:该方法数组中的每个元素执行提供的回调函数。回调函数接受三个参数:当前元素的值、当前元素的索引和数组本身。forEach()方法没有返回值,它只是对每个元素执行回调函数。在给定的代码示例中,使用forEach()方法遍历数组并打印每个元素的值、索引和数组本身。\[2\] 3. join()方法:该方法数组的所有元素连接成一个字符串,并返回该字符串。默认情况下,元素之间使用逗号分隔。在给定的代码示例中,使用join()方法数组中的元素连接成一个字符串,并将结果打印出来。\[3\] 这些是JavaScript中一些常用的数组API方法,它们可以帮助我们更方便地操作和处理数组。 #### 引用[.reference_title] - *1* [JavaScript 数组filter方法完整介绍](https://blog.csdn.net/allway2/article/details/124954994)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [JS数组API大全(持续更新)](https://blog.csdn.net/BBBBobo/article/details/121869585)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值