aboutsummaryrefslogtreecommitdiffstats
path: root/src/core.js
diff options
context:
space:
mode:
authorjeresig <jeresig@gmail.com>2011-04-10 16:46:14 -0400
committerjeresig <jeresig@gmail.com>2011-04-10 16:46:14 -0400
commit247363b9a77281b202de7d535f356a6921a25cf5 (patch)
treea789d12ac420dd46deedeaa6f463f5ea03301328 /src/core.js
parent523db95de2fe9a66e515d75a7cbcce204c40c93b (diff)
parentc0389e3e37447aa7eb70cfb4837f4df6cdec5bba (diff)
downloadjquery-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/core.js')
-rw-r--r--src/core.js27
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;
+ }
}
}