今天看了jQuery.each的源码,突然发现里面包含了一个只供自己内部使用的代码,感觉很新奇,就记下来。
不过我本身并不准备经常用这个东西,因为很有可能会和普通的用法搞混。。。上代码:
// args is for internal usage only
each: function( obj, callback, args ) {
var value,
i = 0,
length = obj.length,
isArray = isArraylike( obj );
if ( args ) {
if ( isArray ) {
for ( ; i < length; i++ ) {
value = callback.apply( obj[ i ], args );
if ( value === false ) {
break;
}
}
} else {
for ( i in obj ) {
value = callback.apply( obj[ i ], args );
if ( value === false ) {
break;
}
}
}
// A special, fast, case for the most common use of each
} else {
if ( isArray ) {
for ( ; i < length; i++ ) {
value = callback.call( obj[ i ], i, obj[ i ] );
if ( value === false ) {
break;
}
}
} else {
for ( i in obj ) {
value = callback.call( obj[ i ], i, obj[ i ] );
if ( value === false ) {
break;
}
}
}
}
return obj;
}
这里面有一个args的第三个参数。上面写的是args这个参数只供内部使用,也就是说是不对外开放的,只是jQuery内部在使用这个。
看了一下,这个args的主要作用是改变了callback的参数。
如果没有args,那么参数是callback(index, value)
如果有了args,那么参数是callback(args1, args2, args3...),同时两个一样的是都是把this给绑定起来。
试了一下,有效。或许以后有什么地方会用到:
$.each([1,2,3], function(n1, n2, n3){
console.log(n1);
console.log(n2);
console.log(n3);
}, [1,2,3])