jQuery plugin to serialize form elements into a json object using <fieldset>
elements.
Form:
<form id="form1">
<input type="text" name="username" value="my user name" />
<fieldset name="address">
<input type="text" name="street" value="654, test street" />
<input type="text" name="country" value="Brazil" />
</fieldset>
<fieldset name="contact">
<input type="text" name="email" value="contact@mysite.com" />
<fieldset name="phones">
<input type="text" name="primary" value="+55 51 123456789" />
<input type="text" name="mobile" value="+55 51 987654987" />
</fieldset>
</fieldset>
<input type="submit" />
</form>
Code:
$(document).ready(() => {
$("#form1").submit(event => {
event.preventDefault()
let data = $("#form1").serializeFields()
console.log(JSON.stringify(data))
})
})
Result:
{
"username": "my user name",
"address": {
"street": "654, test street",
"country": "Brazil"
},
"contact": {
"email": "contact@mysite.com",
"phones": {
"primary": "+55 51 123456789",
"mobile": "+55 51 987654987"
}
}
}
Options:
let data = $("#myform").serializeFields({
fieldset_nameattr: "name",
field_selector: "input:enabled,select:enabled,textarea:enabled",
ignored_fields: "input[type='radio']:not(:checked)"
})
npm install
npm install -g grunt-cli
grunt build
The minified output file will be placed to ./dist folder.
- 0.1.3 Fix for shelljs vulnerability.
- 0.1.2 Remove bower.
- 0.1.1 Add textarea as then default selector.
- 0.1.0 Updated npm.
- 0.0.5 Updated old dependencies.
- 0.0.4 Added support to radio and select inputs.
- 0.0.3 Added support to ignore fields and checkbox fix.
- 0.0.2 Added support to nested elements.
- 0.0.1 First version.
See https://www.npmjs.com/package/jquery-serializefields
npm install jquery-serializefields
Licensed under GPL license.