diff options
author | Ben Alman <cowboy@rj3.net> | 2009-12-16 11:54:12 +0800 |
---|---|---|
committer | John Resig <jeresig@gmail.com> | 2009-12-18 04:01:05 +0800 |
commit | 927e1966debda40d8def96b6a4ea35d2a9d5423c (patch) | |
tree | a24a4181322c1fb39eee78f1c836c75f4e3d3466 /src | |
parent | aa81bb5e458efd25981933c339ac1a0090e6eb0f (diff) | |
download | jquery-927e1966debda40d8def96b6a4ea35d2a9d5423c.tar.gz jquery-927e1966debda40d8def96b6a4ea35d2a9d5423c.zip |
Further modified jQuery 1.4 .param() method to serialize arrays containing non-scalar values. PHP and jQuery BBQ can both deserialize these structures, while rack (as of 1.0.0) cannot.
Diffstat (limited to 'src')
-rw-r--r-- | src/ajax.js | 69 |
1 files changed, 39 insertions, 30 deletions
diff --git a/src/ajax.js b/src/ajax.js index 81225f2cb..aed8dac41 100644 --- a/src/ajax.js +++ b/src/ajax.js @@ -591,7 +591,10 @@ jQuery.extend({ // Serialize an array of form elements or a set of // key/values into a query string param: function( a ) { + var s = [], + + // Set jQuery.param.traditional to true for jQuery <= 1.3.2 behavior. param_traditional = jQuery.param.traditional; function add( key, value ){ @@ -600,8 +603,38 @@ jQuery.extend({ s[ s.length ] = encodeURIComponent(key) + '=' + encodeURIComponent(value); } - // If an array was passed in, assume that it is an array - // of form elements + // Recursively encode parameters from object. + function buildParams( prefix, obj ) { + + if ( jQuery.isArray(obj) ) { + // Serialize array item. + jQuery.each( obj, function(i,v){ + if ( param_traditional ) { + add( prefix, v ); + } else { + // If array item is non-scalar (array or object), encode its numeric + // index to resolve deserialization ambiguity issues. Note that rack + // (as of 1.0.0) can't currently deserialize nested arrays properly, + // and attempting to do so may cause a server error. Possible fixes + // are to modify rack's deserialization algorithm or to provide an + // option or flag to force array serialization to be shallow. + buildParams( prefix + "[" + ( typeof v === "object" || jQuery.isArray(v) ? i : "" ) + "]", v ); + } + }); + + } else if ( !param_traditional && typeof obj === "object" ) { + // Serialize object item. + jQuery.each( obj, function(k,v){ + buildParams( prefix + "[" + k + "]", v ); + }); + + } else { + // Serialize scalar item. + add( prefix, obj ); + } + } + + // If an array was passed in, assume that it is an array of form elements. if ( jQuery.isArray(a) || a.jquery ) { // Serialize the form elements jQuery.each( a, function() { @@ -609,35 +642,11 @@ jQuery.extend({ }); } else { - // Encode parameters from object, recursively. If - // jQuery.param.traditional is set, encode the "old" way - // (the way 1.3.2 or older did it) - jQuery.each( a, function buildParams( prefix, obj ) { - - if ( jQuery.isArray(obj) ) { - jQuery.each( obj, function(i,v){ - // Due to rails' limited request param syntax, numeric array - // indices are not supported. To avoid serialization ambiguity - // issues, serialized arrays can only contain scalar values. php - // does not have this issue, but we should go with the lowest - // common denominator - add( prefix + ( param_traditional ? "" : "[]" ), v ); - }); - - } else if ( typeof obj == "object" ) { - if ( param_traditional ) { - add( prefix, obj ); - - } else { - jQuery.each( obj, function(k,v){ - buildParams( prefix ? prefix + "[" + k + "]" : k, v ); - }); - } - } else { - add( prefix, obj ); - } - }); + // If jQuery.param.traditional is set, encode the "old" way (the way + // 1.3.2 or older did it), otherwise encode params recursively. + jQuery.each( a, buildParams ); } + // Return the resulting serialization return s.join("&").replace(r20, "+"); } |