今天看了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])
时间: 2024-10-29 10:46:43