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);
}
});