javascript forEach函數實現代碼_javascript技巧

來源:互聯網
上載者:User
複製代碼 代碼如下:

function forEach(object, block, context, fn) {
if (object == null) return;
if (!fn) {
if (typeof object == "function" && object.call) {
//遍曆普通對象
fn = Function;
} else if (typeof object.forEach == "function" && object.forEach != arguments.callee) {
//如果目標已經實現了forEach方法,則使用它自己的forEach方法(如標準遊覽器的Array對象)
object.forEach(block, context);
return;
} else if (typeof object.length == "number") {
// 如果是類數組對象或IE的數組對象
_Array_forEach(object, block, context);
return;
}
}
_Function_forEach(fn || Object, object, block, context);
};
function _Array_forEach(array, block, context) {
if (array == null) return;
var i = 0,length = array.length;
if (typeof array == "string") {
for (; i < length; i++) {
block.call(context, array.charAt(i), i, array);
}
}else{
for (;i < length; i++) {
block.call(context, array[i], i, array);
}
}
};
_Function_forEach = function(fn, object, block, context) {
// 這裡的fn恒為Function
for (var key in object) {
//只遍曆區域屬性
if (object.hasOwnProperty(key)) {
//相當於 block(object[key], key)
block.call(context, object[key], key, object);
}
}
};

原作者的一些例子(我翻牆扒過來了!):
複製代碼 代碼如下:

function print(el,index){
alert(index+" : "+el)
}
forEach ([1, 2, 3], print);
forEach ({a: "aa", b: "bb",c: "cc"}, print);
forEach ("司徒正美", print);
forEach(document.styleSheets,function(el){
if(el.href) alert(el.href)
});

<script> function forEach(object, block, context, fn) { if (object == null) return; if (!fn) { if (typeof object == "function" && object.call) { //遍曆普通對象 fn = Function; } else if (typeof object.forEach == "function" && object.forEach != arguments.callee) { //如果目標已經實現了forEach方法,則使用它自己的forEach方法(如標準遊覽器的Array對象) object.forEach(block, context); return; } else if (typeof object.length == "number") { // 如果是類數組對象或IE的數組對象 _Array_forEach(object, block, context); return; } } _Function_forEach(fn || Object, object, block, context); }; function _Array_forEach(array, block, context) { if (array == null) return; var i = 0,length = array.length; if (typeof array == "string") array = array.split(""); for (;i < length; i++) { block.call(context, array[i], i, array); } }; _Function_forEach = function(fn, object, block, context) { // 這裡的fn恒為Function for (var key in object) { //只遍曆區域屬性 if (object.hasOwnProperty(key)) { //相當於 block(object[key], key) block.call(context, object[key], key, object); } } }; function print(el,index){ alert(index+" : "+el) } forEach ([1, 2, 3], print); forEach ({a: "aa", b: "bb",c: "cc"}, print); forEach ("司徒正美", print); forEach(document.styleSheets,function(el){ if(el.href) alert(el.href) }); </script>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

複製代碼 代碼如下:

function Person(name, age) {
this.name = name || "";
this.age = age || 0;
};
Person.prototype = new Person;
var fred = new Person("Fred", 38);
fred.language = "English";//極晚綁定
fred.wife = "Wilma";//極晚綁定
forEach(fred,print)

<script type="text/javascript"> function forEach(object, block, context, fn) { if (object == null) return; if (!fn) { if (typeof object == "function" && object.call) { //遍曆普通對象 fn = Function; } else if (typeof object.forEach == "function" && object.forEach != arguments.callee) { //如果目標已經實現了forEach方法,則使用它自己的forEach方法(如標準遊覽器的Array對象) object.forEach(block, context); return; } else if (typeof object.length == "number") { // 如果是類數組對象或IE的數組對象 _Array_forEach(object, block, context); return; } } _Function_forEach(fn || Object, object, block, context); }; function _Array_forEach(array, block, context) { if (array == null) return; var i = 0,length = array.length; if (typeof array == "string") array = array.split(""); for (;i < length; i++) { block.call(context, array[i], i, array); } }; _Function_forEach = function(fn, object, block, context) { // 這裡的fn恒為Function for (var key in object) { //只遍曆區域屬性 if (object.hasOwnProperty(key)) { //相當於 block(object[key], key) block.call(context, object[key], key, object); } } }; function print(el,index){ alert(index+" : "+el) } function Person(name, age) { this.name = name || ""; this.age = age || 0; }; Person.prototype = new Person; var fred = new Person("Fred", 38); fred.language = "English";//極晚綁定 fred.wife = "Wilma";//極晚綁定 forEach(fred,print) </script>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.