javascript – Sencha Touch 2 – 如何获取表单值?

我有一个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);

那么,我怎样才能获得价值?

谢谢

解决方法

好.经过一些调整后找到了答案.为了后代 – 这是解决方案:

我已经在LoginForm中添加了id:’loginform’,然后在’refs’部分的控制器中添加了loginForm:’#loginin’.
然后我可以用它作为:

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

祝你们好运

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面