Dojo Mobile устанавливает поля при переходе представления

Я создал Bijit (Dojo dijit + бизнес-логика) вместе с классом контроллера. Однако в контроллере я не могу установить значения полей в виджете. Я могу видеть строку "сделал это" на консоли, но значения полей никогда не устанавливаются

Я пытаюсь заполнить данные в форме после перехода в dojo/mobile/view.

Любой совет приветствуется.

HTML Fragment:

<div>
        <label for="streetNumber1">Street Number:</label> <input
            data-dojo-type="dijit/form/TextBox" type="text"
            name="streetNumber1" id="streetNumber1" required="required">
    </div>
    <div>
        <label for="streetName1">Street Name:</label> <input
            data-dojo-type="dijit/form/TextBox" type="text"
            name="streetName1" id="streetName1" required="required">
    </div>
    <div>
        <label for="city1">City:</label> <input
            data-dojo-type="dijit/form/TextBox" type="text" name="city1"
            id="city1">
    </div>
    <div>
        <label for="province1">Province/State:</label> <input
            data-dojo-type="dijit/form/TextBox" type="text" name="province1"
            id="province1">
    </div>
    <div>
        <label for="country1">Country:</label> <input
            data-dojo-type="dijit/form/TextBox" type="text" name="country1"
            id="country1">
    </div>
    <div>
        <label for="zipPostal1">Zip/Postal:</label> <input
            data-dojo-type="dijit/form/TextBox" type="text" name="zipPostal1"
            id="zipPostal1">
    </div>
    <div>
        <label for="email1">Email:</label> <input
            data-dojo-type="dijit/form/TextBox" type="email1" name="email" id="email1">
    </div>

Bijit Class:

    define([ "dijit/_Widget", "dijit/_TemplatedMixin",
            "dijit/_WidgetsInTemplateMixin",
            "dojo/text!customDijits/editAccountTemplate.html",
            "dojox/mobile/TextBox","dijit/form/TextBox",
            "dijit/form/NumberTextBox",
            "dojox/form/Manager", "dojox/mobile/FormLayout" ], function(  
                    _Widget, _TemplatedMixin,
            _WidgetsInTemplateMixin, template) {
        return dojo.declare([ _Widget, _TemplatedMixin, _WidgetsInTemplateMixin ],
                {
                    templateString : template,

                    //function to retrieve the data that was typed in
                    getData : function() {
                        if (this.myForm.validate()) {
                            var values = this.myForm.gatherFormValues();

                            delete values['ownerDocumentBody'];
                            delete values['myForm'];

                            return values;
                        } else {
                            return {
                                "INVALID FORM" : "INVALID"
                            };
                        }
                    },
                    //function that sets the fields to the appropriate data fetched
                    setData : function(values) {
                        this.myForm.setFormValues(values);
                    },
                    //function to clear all the field of the form
                    clearData: function(){
                        this.myForm.reset();
                    }
                });
    });

Controller class:

    define(["dojo/_base/declare", "dojo/on", "dojo/when",
            "dojo/_base/lang", "dojo/_base/array", "dojo/store/Memory",
            "dijit/registry", "dojo/Stateful", "dojo/request/xhr",
            "dijit/Dialog", "dojo/_base/json", "dojo/domReady!" ], 
    function(declare, on, when,
            lang, array, Memory, registry, Stateful, xhr, Dialog, json) {
        return declare([ Stateful ], {
            _customerData : null,
            _getData : null,
            _setData : null,
            _clearData: null,

            constructor : function() {

                this._customerData = registry.byId("editAccountWidget");
                this._getData = registry.byId("submitEditAccount");
                this._setData = registry.byId("setData2");
                this._clearData = registry.byId("clearDetails");
                var myView = registry.byId("editProfileView");


                myView.on("beforeTransitionIn", function() {
                    console.log("Made it");
                    //alert("Made it after transition");
                    xhr("json/customer.json", {
                        handleAs : "json"
                    }).then(lang.hitch(this, function(data) {
                        this._customerData.setData(data);
                    }));
                });

                on(this._setData, "click", lang.hitch(this, function() {
                    alert("Clicked");
                }));

                on(this._clearData, "click", lang.hitch(this, function() {
                    this._customerData.clearData();
                }));
            }
        });
    });

1 ответ

Решение

Мне нужно зацепить в рамках перехода. Это исправлено!

this.myView.on("afterTransitionIn", lang.hitch(this, function() {
                console.log("Made it");
                //alert("Made it after transition");
                xhr("json/customer.json", {
                    handleAs : "json"
                }).then(lang.hitch(this, function(data) {
                    this._customerData.setData(data);
                }));
            }));
Другие вопросы по тегам