JQuery JSON Form Binding
1.0.0
Um plugin leve para vincular dados JSON a formulários. Útil para trabalhar com AJAX e formulários com grande número de campos.
npm i jquery-json-form-binding
ou link 'jquery-json-form-binding.js' da pasta src
É bastante simples de usar. Faça um formulário e chame a função jsonToForm nele, passando os dados json e seu retorno de chamada como opções.
Um formulário simples:
<form id="myform">
<input type="" name="name">
<input type="" name="age">
<input type="" name="gender">
</form>
Agora chame jsonToForm com objeto JSON.
var data = {name: "Waleed", age: 23, gender: "Male"};
$("#myform").jsonToForm(data);
Um formulário com seleção múltipla:
<form id="myform">
<div class="form-field">
<h5>
Text Input
</h5>
<input type="" name="name">
</div>
<div class="form-field">
<h5>
Single Select
</h5>
<select name="country">
<option value="usa">USA</option>
<option value="uk">UK</option>
<option value="germany">Germany</option>
</select>
</div>
<div class="form-field">
<h5>
Multiple Select
</h5>
<select multiple name="skill">
<option value="html">html</option>
<option value="css">css</option>
<option value="javascript">javascript</option>
<option value="node">node</option>
</select>
</div>
<div class="form-field">
<h5>
checkbox example
</h5>
<label>
<input type="checkbox" value="english" name="language" />English</label>
<label>
<input type="checkbox" value="french" name="language" />French</label>
<label>
<input type="checkbox" value="german" name="language" />German</label>
</div>
<div class="form-field">
<h5>
Radio example
</h5>
<label>
<input type="radio" value="male" name="sex" />Male</label>
<label>
<input type="radio" value="female" name="sex" />Female</label>
</div>
</form>
Agora chame jsonToForm com objeto JSON.
var json = {
name: "Waleed",
country: "uk",
skill: ["html", "javascript"],
language: ["english", "german"],
sex: "female"
};
$("#myform").jsonToForm(json);
console.log($("#myform").serialize());
Demonstração para seleção múltipla.
Se você tiver um formulário complexo. Você pode usar funções de retorno de chamada para cada chave de dados existente em seu objeto de dados, assim:
var data = {name: "Waleed", age: 23, gender: "Male"};
$("#myform").jsonToForm(data, {
// change the way age value will be set in the form
age: function(value){
$('[name="age"]').val(value+1);
}
});