JS forEach函數


引自:http://www.jb51.net/article/67441.htm

英文參考:http://www.tutorialspoint.com/javascript/array_foreach.htm

 JavaScript數組的 forEach()方法調用數組中的每個元素。
語法

array.forEach(callback[, thisObject]);

下面是參數的詳細信息:

  •     callback : 測試數組中每個元素的函數。 Function to test for each element of an array.
  •     thisObject : 執行回調函數時用作this所指的對象。 Object to use as this when executing callback.

返回值:

返回創建數組。
兼容性:

這種方法是一個JavaScript擴展到ECMA-262標准;因此它可能不存在在標准的其他實現。為了使它工作,你需要添加下面的腳本代碼的頂部:

if (!Array.prototype.forEach)
{
 Array.prototype.forEach = 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);
  }
 };
}

 

例子:

<html>
<head>
<title>JavaScript Array forEach Method</title>
</head>
<body>
<script type="text/javascript">
if (!Array.prototype.forEach)
{
 Array.prototype.forEach = 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);
  }
 };
}

function printBr(element, index, array) {
 document.write("<br />[" + index + "] is " + element ); 
}

[12, 5, 8, 130, 44].forEach(printBr);
 
</script>
</body>
</html>

 

這將產生以下結果:

[0] is 12
[1] is 5
[2] is 8
[3] is 130
[4] is 44 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM