Sencha Touch 2 - Как получить значения формы? - PullRequest
6 голосов
/ 13 марта 2012

У меня есть приложение Sencha Touch 2 MVC с формой в качестве представления.Я пытаюсь получить его значения из контроллера безуспешно.

Как это можно сделать?Я публикую свой код вида / контроллера для этого.

Вид:

Ext.define('MyApp.view.LoginForm', {
    extend: 'Ext.form.Panel',
    config: {
        fullscreen: true,
        items: [
            {
                xtype: 'fieldset',
                title: 'Login',
                id: 'loginform',
                items: [
                    {
                        xtype: 'emailfield',
                        name: 'email',
                        label: 'Email'
                    },
                    {
                        xtype: 'passwordfield',
                        name: 'password',
                        label: 'Password'
                    }
                ]
            },
            {
                xtype: 'button',
                width: '50%',
                text: 'Login',
                ui: 'confirm',
                id: 'btnSubmitLogin'
            },
            {
                xtype: 'toolbar',
                docked: 'top',
                title: 'MyApp Mobile'
            }
        ]
    }
});

И контроллер:

Ext.define("MyApp.controller.LoginForm", {
    extend: "Ext.app.Controller",
    config: {
        refs: {
            btnSubmitLogin: "#btnSubmitLogin"
        },
        control: {
            btnSubmitLogin: {
                tap: "onSubmitLogin"
            }
        }
    },
    onSubmitLogin: function () {
        console.log("onSubmitLogin");
        var values = app.views.LoginForm.loginform.getValues();
        TryLogin(values['email'], values['password']);
    },
    launch: function () {
        this.callParent();
        console.log("LoginForm launch");
    },
    init: function () {
        this.callParent();
        console.log("LoginForm init");
    }
});

Код будет до

console.log("onSubmitLogin");

И затем остановка.

При запуске я использую это:

var LoginForm = Ext.create("MyApp.view.LoginForm");
Ext.Viewport.add(LoginForm);

Итак, как я могу получить значения?

Спасибо

Ответы [ 2 ]

17 голосов
/ 13 марта 2012

Хорошо.Нашел ответ после некоторых настроек.Ради будущих поколений - вот решение:

Я добавил id:'loginform' в LoginForm, а затем в контроллере в части 'refs' добавил loginForm: '#loginform'.Тогда я мог бы использовать это как:

var values = this.getLoginForm().getValues();

Удачи всем

0 голосов
/ 03 июня 2012

Попробуйте это

Контроллер:


    Ext.define("mySIMS.controller.LoginForm", {
        extend : "Ext.app.Controller",
        config : {
            refs : {
                btnSubmitLogin : "#btnSubmitLogin",
                LoginForm : '#loginform'
            },
            control : {
                btnSubmitLogin : {
                    tap : "onSubmitLogin"
                }
            }
        },
        onSubmitLogin : function() {
            console.log("onSubmitLogin");
            var values = this.getLoginForm().getValues();
            console.log(values);

            //var values = Oreilly.views.LoginForm.loginform.getValues();

        },
        launch : function() {
            this.callParent();
            console.log("LoginForm launch");
        },
        init : function() {
            this.callParent();
            console.log("LoginForm init");
        }
    });

Вид:


    Ext.define('mySIMS.view.LoginForm', {
        extend : 'Ext.form.Panel',
        config : {
            id : 'loginform',
            fullscreen : true,
            items : [{
                xtype : 'fieldset',
                title : 'Login',
                items : [{
                    xtype : 'emailfield',
                    name : 'email',
                    label : 'Email'
                }, {
                    xtype : 'passwordfield',
                    name : 'password',
                    label : 'Password'
                }]
            }, {
                xtype : 'button',
                width : '8%',
                text : 'Login',
                ui : 'confirm',
                id : 'btnSubmitLogin'
            }, {
                xtype : 'toolbar',
                docked : 'top',
                title : 'Mobile'
            }]
        }
    });

Надеюсь, что это поможет.

...