JQuery JSON Form Binding
1.0.0
一个轻量级插件,用于将 JSON 数据绑定到表单。对于使用 AJAX 和具有大量字段的表单很有用。
npm i jquery-json-form-binding
或从 src 文件夹链接“jquery-json-form-binding.js”
使用起来相当简单。创建一个表单并在其上调用 jsonToForm 函数,传递 json 数据和您的回调作为选项。
一个简单的形式:
<form id="myform">
<input type="" name="name">
<input type="" name="age">
<input type="" name="gender">
</form>
现在使用 JSON 对象调用 jsonToForm。
var data = {name: "Waleed", age: 23, gender: "Male"};
$("#myform").jsonToForm(data);
具有多选功能的表单:
<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>
现在使用 JSON 对象调用 jsonToForm。
var json = {
name: "Waleed",
country: "uk",
skill: ["html", "javascript"],
language: ["english", "german"],
sex: "female"
};
$("#myform").jsonToForm(json);
console.log($("#myform").serialize());
多重选择演示。
如果您有复杂的表格。您可以对数据对象中的每个数据键使用传递回调函数,如下所示:
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);
}
});