diff options
author | jeresig <jeresig@gmail.com> | 2011-04-10 16:46:14 -0400 |
---|---|---|
committer | jeresig <jeresig@gmail.com> | 2011-04-10 16:46:14 -0400 |
commit | 247363b9a77281b202de7d535f356a6921a25cf5 (patch) | |
tree | a789d12ac420dd46deedeaa6f463f5ea03301328 /src | |
parent | 523db95de2fe9a66e515d75a7cbcce204c40c93b (diff) | |
parent | c0389e3e37447aa7eb70cfb4837f4df6cdec5bba (diff) | |
download | jquery-247363b9a77281b202de7d535f356a6921a25cf5.tar.gz jquery-247363b9a77281b202de7d535f356a6921a25cf5.zip |
Merge branch 'map-object.1.6' of https://github.com/danheberden/jquery into danheberden-map-object.1.6
Diffstat (limited to 'src')
-rw-r--r-- | src/core.js | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/src/core.js b/src/core.js index 323349e8b..b882f9b42 100644 --- a/src/core.js +++ b/src/core.js @@ -710,15 +710,30 @@ jQuery.extend({ // arg is for internal usage only map: function( elems, callback, arg ) { - var ret = [], value; + var value, key, ret = [], + i = 0, + length = elems.length, + // jquery objects are treated as arrays + isArray = elems instanceof jQuery || length !== undefined && typeof length === "number" && ( ( length > 0 && elems[ 0 ] && elems[ length -1 ] ) || jQuery.isArray( elems ) ) ; // Go through the array, translating each of the items to their - // new value (or values). - for ( var i = 0, length = elems.length; i < length; i++ ) { - value = callback( elems[ i ], i, arg ); + if ( isArray ) { + for ( ; i < length; i++ ) { + value = callback( elems[ i ], i, arg ); + + if ( value != null ) { + ret[ ret.length ] = value; + } + } - if ( value != null ) { - ret[ ret.length ] = value; + // Go thorugh every key on the object, + } else { + for ( key in elems ) { + value = callback( elems[ key ], key, arg ); + + if ( value != null ) { + ret[ ret.length ] = value; + } } } |