判断某一项是否在数组中几种方式


prtyaa
prtyaa 2023-12-26 18:39:06 62280
分类专栏: 资讯

方式一 includes方法

let arr = ['甲', '乙', '丙', '丁']

console.log(arr.includes('甲')) // true
console.log(arr.includes('戊')) // false

方式二 indexOf方法

let arr = ['甲', '乙', '丙', '丁']

console.log(arr.indexOf('甲')) // 0 (有就返回索引0~n)
console.log(arr.indexOf('戊')) // -1 (没有就返回-1)

方式三 findIndex方法

let arr = ['甲', '乙', '丙', '丁']

let flag1 = arr.findIndex((item) => {
    return item == '甲'
})
console.log(flag1) // 0 (有就返回索引0~n)

let flag2 = arr.findIndex((item) => {
    return item == '戊'
})
console.log(flag2) // -1 (没有就返回-1)

方式四 some方法

let arr = ['甲', '乙', '丙', '丁']

let flag3 = arr.some((item) => { // 只要有一个存在就返回true
    return item == '甲'
})
console.log(flag3) // true

let flag4 = arr.some((item) => { // 一个都不存在才返回false
    return item == '戊'
})
console.log(flag4) // false

方式五 定义标识加常见的循环

// 定义标识搭配循环for、forEach...

let arr = ['甲', '乙', '丙', '丁']

let flag5 = false // 默认不存在
arr.forEach((item) => {
    if (item == '甲') { // 戊
        flag5 = true
    }
})
console.log(flag5) // true // false

注意

简单数组使用includes或indexOf

类似这种简单的数组数组中只有单一项内部存储的字符串或者数字之类的
使用includes或indexOf方便一些
arr = [1,2,3,4,5]
arr2 = ['发财','白皮','红中']

复杂些的数组使用另外几个

如带层级的数组数组中对象或更多层级的结构这个时候需要使用带回调函数的方法
此时再去使用includes或indexOf就不够用了
arr3 = [
            {
                    name: '孙悟空',
                    age: 500
            },
            {
                    name: '猪八戒',
                    age: 88
            },
            {
                    name: '沙和尚',
                    age: 1000
            },
        ]

面试题:includes和indexOf的最大区别

最大的区别就是 - indexOf是 === - includes是 ==

indexOf要求严格,无法正确判断数组中是否有NaN 但是includes可以

let arr = [NaN, 1, undefined]
console.log(arr.includes(NaN)) // true
console.log(arr.indexOf(NaN)) // -1
// undefined不受影响
console.log(arr.includes(undefined)) // true
console.log(arr.indexOf(undefined)) // 2

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=31028
赞同 0
评论 0 条
prtyaaL1
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1515
银河麒麟打印带有图像的文档时出错  1434
银河麒麟添加打印机时,出现“server-error-internal-error”  1226
统信操作系统各版本介绍  1145
统信桌面专业版【如何查询系统安装时间】  1141
统信桌面专业版【全盘安装UOS系统】介绍  1099
麒麟系统也能完整体验微信啦!  1053
统信【启动盘制作工具】使用介绍  705
统信桌面专业版【一个U盘做多个系统启动盘】的方法  648
信刻全自动档案蓝光光盘检测一体机  551
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
如何玩转信创开放社区—从小白进阶到专家 15
信创开放社区邀请他人注册的具体步骤如下 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!