ExtJS: на основе значений в выпадающем списке скрыть и показать поля и передать их в springMVC - PullRequest
1 голос
/ 25 марта 2012

У меня есть два выпадающих списка в extjs, основанных на первом выпадающем списке, заполняется второй. Это нормально работает, и я могу передать значения в springMVC, но проблема возникает, когда мне нужно скрыть / показать текстовые поля, основанные на второй выпадающий список, скрытие / скрытие работает нормально, но я не могу передать параметры SpringMVC. Вот мои файлы .js. Кто-нибудь может сказать, где я должен исправить,

Ext.Loader.setConfig({
enabled: true
});
Ext.require(['*']);

var country = Ext.create('Ext.data.Store', {
fields: ['abbr', 'name'],
data: [{
    "abbr": "USA",
    "name": "USA"
}, {
    "abbr": "UK",
    "name": "UK"
},


]
});

var states = Ext.create('Ext.data.Store', {
fields: ['id', 'abbr', 'name'],
data: [{
    "id": "New York",
    "abbr": "USA",
    "name": "New York"
}, {
    "id": "New Jersey",
    "abbr": "USA",
    "name": "New Jersey"
}, {
    "id": "London",
    "abbr": "UK",
    "name": "London"
}, {
    "id": "Hampshire",
    "abbr": "UK",
    "name": "Hampshire"
}]
});
Ext.define('App.view.countryPanel', {
extend: 'Ext.form.Panel',
alias: 'widget.CountryPanel',
id: 'countrypanel',


title: 'Country',
frame: true,
width: 400,
fieldDefaults: {
    labelWidth: 200
},
bodyPadding: '15 16 10',

height: 200,
id: 'countrypanel',

method: 'POST',




items: [



{
    xtype: 'combo',
    id: 'con',
    name: 'con',
    fieldLabel: 'Country',
    displayField: 'name',

    emptyText: 'Select a Country',
    valueField: 'abbr',
    store: country,
    listeners: {
        'select': {
            fn: function (combo, value) {

                var comboState = Ext.getCmp('statelist');
                comboState.bindStore(states);
                comboState.clearValue();
                comboState.store.filter('abbr', combo.getValue());

                states = Ext.create('Ext.data.Store', {
                    fields: ['id', 'abbr', 'name'],
                    data: [{
                        "id": "New York",
                        "abbr": "USA",
                        "name": "New York"
                    }, {
                        "id": "New Jersey",
                        "abbr": "USA",
                        "name": "New Jersey"
                    }, {
                        "id": "London",
                        "abbr": "UK",
                        "name": "London"
                    }, {
                        "id": "Hampshire",
                        "abbr": "UK",
                        "name": "Hampshire"
                    }]
                });



            }
        }
    }
}, {
    xtype: 'combo',
    id: 'statelist',
    name: 'statelist',
    fieldLabel: 'Stated',
    displayField: 'name',
    emptyText: 'Select states',
    valueField: 'id',
    store: states,
    listeners: {
        'select': {
            fn: function (combo, value) {
                var sample = combo.getValue();




                if (sample == 'London') {


                    Ext.getCmp('Tower').getEl().show();


                } else {

                    Ext.getCmp('Tower').getEl().hide();
                    Ext.getCmp('Liberty').getEl().show();

                }


                var comboState = Ext.getCmp('statelist');
                comboState.bindStore(states);
                comboState.clearValue();
                comboState.store.filter('abbr', combo.getValue());



            }
        }
    }
}, {
    xtype: 'textfield',
    id: 'Tower',
    name: 'Tower',
    fieldLabel: 'ClockTower',
    hidden: true,

    allowBlank: false

}, {
    xtype: 'textfield',
    id: 'Liberty',
    name: 'Liberty',
    fieldLabel: 'Liberty',
    hidden: true,
    minWidth: 20,
    allowBlank: false

}],
buttonAlign: 'center',
buttons: [

{
    text: 'Submit',
    handler: function () {

        var sspanel = Ext.getCmp('countrypanel');
        var form = sspanel.getForm();


        form.submit({


            url: 'country.htm',


            success: function (form, action) {


                Ext.Msg.alert('Success');




            },

            failure: function (form, action) {

                Ext.Msg.alert('failure');
            }



        });


    }

},

{

    text: 'Reset',
    handler: function () {
        var sspanel = Ext.getCmp('countrypanel');
        var form = sspanel.getForm();
        form.reset();
    }
}

]

});

1 Ответ

0 голосов
/ 06 апреля 2012

Попробуйте использовать опцию конфигурации hideMode для текстовых полей:

{
    xtype: 'textfield',
    id: 'Liberty',
    name: 'Liberty',
    fieldLabel: 'Liberty',
    hidden: true,
    hideMode: 'visibility', // you may also use 'offsets' 
    minWidth: 20,
    allowBlank: false
}

В этом случае значения полей будут переданы в качестве параметров.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...