• 首页
  • vue
  • TypeScript
  • JavaScript
  • scss
  • css3
  • html5
  • php
  • MySQL
  • redis
  • jQuery
  • TypedArray.prototype.every()

    every()方法测试类型化数组的所有元素是否都能够通过由提供函数实现的测试。这个方法的算法与Array.prototype.every()相同。TypedArray是这里的类型化数组类型之一。

    语法

    typedarray.every(callback[, thisArg])
    

    参数

    callback
    用于测试每个元素的函数,接受三个参数:
    currentValue
    要处理的类型化数组的当前元素。
    index
    要处理的当前元素在类型化数组中的下标
    array
    every 在其上调用的类型化数组
    thisArg
    可选,执行callback 时的this值。

    返回值

    如果函数对数组每个元素返回 truthy ,则为true,否则为false

    描述

    every方法为类型化数组中的每个元素执行一次callback函数,直到它找到一个使callback返回false(表示可转换为布尔值 false 的值)的元素。如果发现了一个这样的元素,every方法将会立即返回false。否则,callback为每一个元素返回trueevery就会返回truecallback只会为那些已经被赋值的索引调用。不会为那些被删除或从来没被赋值的索引调用。

    callback以三个参数调用:元素的值,元素索引,以及要遍历的数组对象。

    如果将thisArg参数提供给every,它会在调用时传递给callback,作为它的this值。否则,会传递undefined作为它的this值。callback最终观测到的this值由用于决定函数可见的this值的一般规则来决定。

    every不修改在其上调用的类型化数组。

    示例

    测试类型化数组所有元素的大小

    下面的示例测试了类型化数组所有元素是否大于 10。

    function isBigEnough(element, index, array) {
      return element >= 10;
    }
    new Uint8Array([12, 5, 8, 130, 44]).every(isBigEnough);   // false
    new Uint8Array([12, 54, 18, 130, 44]).every(isBigEnough); // true
    

    使用箭头函数测试类型化数组的元素

    箭头函数为相同测试提供了更短的语法。

    new Uint8Array([12, 5, 8, 130, 44]).every(elem => elem >= 10); // false
    new Uint8Array([12, 54, 18, 130, 44]).every(elem => elem >= 10); // true