avevo bisogno di fare questo io stesso e dopo aver trovato questa domanda non mi piaceva nessuna delle risposte: Non mi piace regex e gli altri sono limitati.
È possibile ottenere la variabile data
in molti modi. Utilizzerò il metodo serializeArray
di jQuery durante l'implementazione.
function parseInputs(data) {
var ret = {};
retloop:
for (var input in data) {
var val = data[input];
var parts = input.split('[');
var last = ret;
for (var i in parts) {
var part = parts[i];
if (part.substr(-1) == ']') {
part = part.substr(0, part.length - 1);
}
if (i == parts.length - 1) {
last[part] = val;
continue retloop;
} else if (!last.hasOwnProperty(part)) {
last[part] = {};
}
last = last[part];
}
}
return ret;
}
var data = {
"nom": "123",
"items[install][item_id_4]": "4",
"items[install][item_id_5]": "16",
"items[options][takeover]": "yes"
};
var out = parseInputs(data);
console.log('\n***Moment of truth:\n');
console.log(out);
Con "Pure JavaScript", suppongo che intendi "Senza utilizzare JavaScript scritto da altre persone, come i team jQuery o YUI"? (Al contrario di "Senza Flash" o "Senza DOM"?) – Quentin
Tecnicamente, jQuery *** è *** "puro JavaScript". Vuoi capire come leggere [elementi del form con plain-old DOM] (https://developer.mozilla.org/en/DOM/HTMLFormElement) o vuoi essere più produttivo e Get Stuff Done? –
è 'querySelectorAll' anche puro? – pimvdb