详解JavaScript中的every()方法

2019-12-18,,,

 JavaScript 数组中的每个方法测试数组中的所有元素是否经过所提供的函数来实现测试。
语法

array.every(callback[, thisObject]);

下面是参数的详细信息:

  •     callback : 函数用来测试每个元素
  •     thisObject : 对象作为该执行回调时使用

返回值:

返回true,如果此数组中的每个元素满足所提供的测试函数。
兼容性:

这种方法是一个JavaScript扩展到ECMA-262标准;因此它可能不存在在标准的其他实现。为了使它工作,你需要添加下面的脚本的代码在顶部:

if (!Array.prototype.every)
{
 Array.prototype.every = function(fun /*, thisp*/)
 {
  var len = this.length;
  if (typeof fun != "function")
   throw new TypeError();

  var thisp = arguments[1];
  for (var i = 0; i < len; i++)
  {
   if (i in this &&
     !fun.call(thisp, this[i], i, this))
    return false;
  }

  return true;
 };
}

例子:

<html>
<head>
<title>JavaScript Array every Method</title>
</head>
<body>
<script type="text/javascript">
if (!Array.prototype.every)
{
 Array.prototype.every = function(fun /*, thisp*/)
 {
  var len = this.length;
  if (typeof fun != "function")
   throw new TypeError();

  var thisp = arguments[1];
  for (var i = 0; i < len; i++)
  {
   if (i in this &&
     !fun.call(thisp, this[i], i, this))
    return false;
  }

  return true;
 };
}
function isBigEnough(element, index, array) {
 return (element >= 10);
}

var passed = [12, 5, 8, 130, 44].every(isBigEnough);
document.write("First Test Value : " + passed ); 
 
passed = [12, 54, 18, 130, 44].every(isBigEnough);
document.write("Second Test Value : " + passed ); 
</script>
</body>
</html>

这将产生以下结果:

First Test Value : falseSecond Test Value : true

您可能感兴趣的文章:

  • Vue.js报错Failed to resolve filter问题的解决方法
  • JavaScript 数组some()和filter()的用法及区别
  • JavaScript中的some()方法使用详解
  • Some tips of wmi scripting in jscript (1)
  • jquery.fileEveryWhere.js 一个跨浏览器的file显示插件
  • 详解JavaScript中的forEach()方法的使用
  • js的for in循环和java里foreach循环的区别分析
  • js中的for如何实现foreach中的遍历
  • 全面解析JavaScript里的循环方法之forEach,for-in,for-of
  • 浅析JS中的 map, filter, some, every, forEach, for in, for of 用法总结

《详解JavaScript中的every()方法.doc》

下载本文的Word格式文档,以方便收藏与打印。