0

私は sencha touch を初めて使用します。以下のコードでエラーが発生します error:Uncaught TypeError: Object [object Object] has no method 'getValues'

                           var uswrfeild =  Ext.getCmp('User_details');
                                //var fieldset = Ext.create('FieldSet_PersonalSettings');
                                //var fieldset= this.tab;
                                var values = uswrfeild.getValues();
                                cart = Ext.create('Items');
                                //alert(values);
                                //cart.add({field1:'value1',field2:'value2'});
                                cart.add(values);
                                cart.sync();

以下のコードはフィールドセットコードです

                    {
                        xtype: 'container',
                        title: 'User',
                        id: 'User_details',
                        itemId: 'mycontainer3',
                        scrollable: 'vertical',
                        items: [
                            {
                                xtype: 'fieldset',
                                id: 'FieldSet_PersonalSettings',
                                itemId: 'myfieldset12',
                                margin: '2%',
                                title: 'User',
                                items: [
                                    {
                                        xtype: 'textfield',
                                        label: 'Name',
                                        name: 'name',
                                        maxLength: 31,
                                        placeHolder: 'given-name family-name'
                                    },
                                    {
                                        xtype: 'emailfield',
                                        label: 'Email',
                                        name: 'email',
                                        required: true,
                                        maxLength: 63,
                                        placeHolder: 'name@example.com'
                                    },
                                    {
                                        xtype: 'textfield',
                                        label: 'Street',
                                        name: 'street',
                                        required: true,
                                        placeHolder: 'streetname'
                                    },
                                    {
                                        xtype: 'textfield',
                                        label: 'House Number',
                                        required: true,
                                        placeHolder: '123'
                                    },
                                    {
                                        xtype: 'textfield',
                                        label: 'Zipcode',
                                        required: true,
                                        autoCapitalize: true,
                                        maxLength: 10,
                                        placeHolder: '1234AA'
                                    },
                                    {
                                        xtype: 'textfield',
                                        label: 'Country',
                                        required: true,
                                        placeHolder: 'NL'
                                    }
                                ]
                            },
                            {
                                xtype: 'fieldset',
                                margin: '2%',
                                title: 'Sharing information',
                                items: [
                                    {
                                        xtype: 'checkboxfield',
                                        label: 'Receive email',
                                        labelWidth: '75%',
                                        checked: true
                                    },
                                    {
                                        xtype: 'checkboxfield',
                                        height: 49,
                                        label: 'Upload statistics (anonymously)',
                                        labelWidth: '75%',
                                        checked: true
                                    }
                                ]
                            }

ベロコードはモデルです

Ext.define('iFP.model.item', {
    extend: 'Ext.data.Model',

    config: {
        fields: [
            {
                name: 'name',
                type: 'string'
            },
            {
                name: 'email',
                type: 'string'
            },
            {
                name: 'street',
                type: 'string'
            },
            {
                name: 'hno',
                type: 'auto'
            },
            {
                name: 'zipcode',
                type: 'int'
            },
            {
                name: 'country',
                type: 'string'
            }
        ]
    }
});

以下のコードはストアです

        Ext.define('iFP.store.userlocalsettings', {
    extend: 'Ext.data.Store',

    requires: [
        'iFP.model.item'
    ],

    config: {
        autoSync: false,
        model: 'iFP.model.item',
        storeId: 'usersettingslocalstore',
        proxy: {
            type: 'localstorage'
        }
    }
});

私の目的は、テキストのフィード値がブラウザーのローカルストアに保存されることです。仲間を助けてください。前もって感謝します。

4

2 に答える 2

0

たとえば、次のように、最初に各フィールドのIDを設定する必要があります

 {
      xtype: 'textfield',
      label: 'Name',
      name: 'name',
      maxLength: 31,
      placeHolder: 'given-name family-name',
      itemId: 'tfName'
 },

次に、関数内のいくつかのイベントの後にフィールドの値を取得できます

var namefield = this.down('#tfName'); 
var namevalue = namefield.getValue();

...

そして、その値を追加して保存できます

var store = Ext.getStore('userlocalsettings');
store.add({name: namevalue});
store.sync();

これが役立つことを願っています。

于 2013-02-07T17:57:44.040 に答える
0

フォームの ID を設定する必要があります。

config: {
        itemId: 'form1'
}

次に、コントローラーでそのIDへの参照を追加します

refs: {
      myPanel: '#form1'
}

ボタン リスナーが表示されません。リスナーの名前が「onTapSave」だとしたら、これを試してください。

onTapSave: function(component,button, options){

    var uswrfeild = this.getMyPanel();
    var values = uswrfeild.getValues();
}
于 2013-05-17T06:51:09.137 に答える