Sérialiser un formulaire en tableau associatif avec jQuery
Cette extension pour jQuery permet de serialiser un formulaire en produisant pour chacun de ses éléments un objet avec les clés name et value, regroupés dans un tableau.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
$.fn.serializeAssoc = function() { var data = {}; $.each( this.serializeArray(), function(key, obj){ var a = obj.name.match(/(.*?)\[(.*?)\]/); if(a !== null){ var subName = a[1]; var subKey = a[2]; if( !data[subName] ) data[subName] = []; if( data[subName][subKey] ){ if( $.isArray( data[subName][subKey] ) ){ data[subName][subKey].push(obj.value); }else{ data[subName][subKey] = []; data[subName][subKey].push(obj.value); } }else{ data[subName][subKey] = obj.value; } }else{ if( data[obj.name] ){ if( $.isArray( data[obj.name] ) ){ data[obj.name].push( obj.value ); }else{ data[obj.name] = []; data[obj.name].push( obj.value ); } }else{ data[obj.name] = obj.value; } } }); return data; }; |
1 2 |
var formData = $('form').serializeAssoc(); console.log(formData); |