ここでは、dojo.toJson を使用して dijit.form.TextBox を json 形式に変換します。入力がないと、"" であると予想される "null" が返されます。
ソースコードは次のとおりです。
//aspx コード
<input id="name" data-dojo-type="dijit.form.TextBox" data-dojo-props="name:'name'" />
<button id="submitButton" data-dojo-type="dijit.form.Button" type="button">
submit</button>
//js コード
define("views/Test", [
"dojo",
"dojo/parser",
"dijit/form/Form",
"dijit/form/TextBox",
"dijit/form/Button"
], function () {
dojo.declare("views.Test", null, {
onSubmitClick: function () {
var jsonData = dojo.toJson(dijit.byId("name").get("value")); // here: dijit.byId("name").get("value") is "" and jsonData is ""null""
},
startup: function () {
dojo.connect(dijit.byId("submitButton"), "onClick", this, this.onSubmitClick);
}
});
return views.Test;
});
次の2つに違いはありますか?結果が全然違うから
dojo.toJson("") // returns """"
dojo.toJson(dijit.byId("XXX").get("value")) //returns ""null""
環境情報: IE 8 Dojo バージョン: 1.7