• 技术文章 >web前端 >js教程

    es6怎么判断数组中是否包含某一项值

    青灯夜游青灯夜游2022-03-07 18:35:31原创72

    在es6中,可以利用数组的includes()方法来判断数组中是否包含某一项值,该方法可以用来检测数组中是否包含某个值,语法“数组对象.includes(值)”。

    本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

    在ES5,Array已经提供了 indexOf用来查找某个元素的位置,如果不存在就返回-1,但是这个函数在判断数组是否包含某个元素时有两个小不足,第一个是它会返回-1和元素的位置来表示是否包含,在定位方面是没问题,就是不够语义化。另一个问题是不能判断是否有NaN的元素。

    例如:

    const arr1 = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', NaN]
    console.log('%s', arr1.indexOf(NaN))

    结果:

    -1

    ES6提供了Array.includes()函数判断是否包含某一元素,除了不能定位外,解决了indexOf的上述的两个问题。它直接返回true或者false表示是否包含元素,对NaN一样能有有效。

    const arr1 = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', NaN]
    console.log('%s', arr1.includes('c'))
    console.log('%s', arr1.includes('z'))
    console.log('%s', arr1.includes(NaN))

    结果:

    true
    false
    true

    includes()函数的第二个参数表示判断的起始位置。

    const arr1 = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', NaN]
    console.log('%s', arr1.includes('d', 1))
    console.log('%s', arr1.includes('d', 3))
    console.log('%s', arr1.includes('d', 4))

    结果:

    true
    true
    false

    第二个参数也可以是负数,表示从右数过来第几个,但是不改变判断搜索的方向,搜索方向还是从左到右。

    console.log('%s', arr1.includes('k', -1))
    console.log('%s', arr1.includes('k', -2))
    console.log('%s', arr1.includes('i', -3))

    结果:

    false
    true
    false

    总结:

    includes()方法,用来检测数组中是否包含某个值,可以判断NaN,而且直接返回true/false,比较直观;

    indexOf()方法,用来查找某个元素的位置,不能判断NaN,返回-1,即不包含,非-1即当前包含的位置。

    两个方法各有长短,依实际情况定。如果元素包含NaN,就用includes(),否则两者均可。

    【相关推荐:javascript视频教程web前端

    以上就是es6怎么判断数组中是否包含某一项值的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:实例图文详解在JavaScript中实现队列 下一篇:手把手教你在node中怎么优雅打印全链路日志
    PHP编程就业班

    相关文章推荐

    • symbol是es6中的新增类型吗• es6声明变量有几种方法• es6中怎么将set转化为数组• es6合并对象的方法有哪些• es6怎么判断数组是否含有相同的值

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网