zoukankan      html  css  js  c++  java
  • ES6,Array.includes()函数的用法

    在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

    End

  • 相关阅读:
    家庭记账本1
    寒假福利5
    寒假福利4——定位功能
    寒假福利3——日期时间选择器
    寒假作业——家庭小账本1.6(总结)
    寒假作业——家庭小账本1.5
    寒假作业——家庭小账本1.4
    寒假作业——家庭小账本1.3
    寒假作业——家庭小账本1.2
    寒假作业——家庭小账本1.1
  • 原文地址:https://www.cnblogs.com/kongxianghai/p/7560343.html
Copyright © 2011-2022 走看看