JavaScript中some 和 every的区别和用法

 前言

开发中,经常会用到js的Array数组的各种迭代函数map(),filter(),some(),every(),forEach(),find() findIndex(),也是在ES6中新增一些遍历函数。同样是不是也是一道面试题,说说ES6新增的一些新特性????

例如:要检测数组中的元素是否满足指定条件,然后直接返回布尔值方便进行判定操作
这里javascript里的数组方法 some和every就能很好的解决这种问题

 正文

相同点:every和some都有三个参数,即item-当前项,index-当前项的索引值,array-数组本身;都可循环遍历数组
不同点:every相当于逻辑关系中的且,只有所有参数都满足条件时,才返回true,一旦有一个不满足,则逻辑中断,返回false;some相当于逻辑关系中的或,只要有一个参数满足条件,就中断遍历,返回true,若遍历完所有参数,没有符合的项,返回false

通俗一点就是 every:一假即假,some:一真即真

注意: some() 不会对空数组进行检测。
注意: some() 不会改变原始数组。

 1.some

第一个参数: item,必须,当前元素的值

第二个参数 : index,可选,当前元素在数组中的索引值

第三个参数 : arr,当前元素所处的数组对象

语法

array.some( function ( item, index,arr) {} )

实际中运用

const arr = [1,2,3,4]; 
let a = arr.some((item)=>{return item>1})
console.log(a)
//打印结果: true

 数组对象也可使用,用法相同

const arr = [
      {
        name: 'test'
      },
      {
        name: 'test2'
      }
    ]
    const b = arr.some(item => item.name === 'test')
    console.log(b) // true
 2.every

第一个参数: item,必须,当前元素的值

第二个参数 : index,可选,当前元素在数组中的索引值

第三个参数 : arr,当前元素所处的数组对象

语法

array.every( function ( item, index,arr) {} )

实际中运用

const arr = [1,2,3,4,5]
const c = arr.every(item => item >= 5)
console.log(c) // 打印结果: true

数组对象也可使用,用法相同

	const arr = [
      {
        name: 'test'
      },
      {
        name: 'test2'
      }
    ]
    const d= arr.every(item => item.name === 'test')
    console.log(d) // false

总结

两个都是用法相似的方法,只是略有区别
some() 方法如果有一个元素满足条件,则表达式返回true,剩余的元素不会再执行检测,所有元素都不满足条件时才返回false。
every() 方法如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测。需要所有的元素都满足条件才返回true。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值