У меня маленькая проблема.В моем приложении я всегда строю два связанных поля со списком - страна и города (затем выбирается страна - города начинают загружаться).Поэтому я подумал - я могу написать конструктор и свернуть мой код?Хорошо, я сделал это.Но у меня возникла проблема: у меня есть 2-3 пары этих связанных комбинированных списков на странице, и когда я выбираю во второй стране со списком, данные (города) загружаются при первой комбинации, потому что у них одинаковый идентификатор.Хорошо, теперь я пытаюсь передать идентификатор параметра конструктору, и это не сработало.Как установить идентификатор поля со списком, тогда я создаю объект?
Страна комбо
comboCountryClass = Ext.extend(Ext.form.ComboBox, {
fieldLabel: 'country',
anchor: '95%',
lazyRender:true,
store:new Ext.data.Store({
proxy: new Ext.data.HttpProxy(
{url: '../lib/getRFB.php?rfb_type=countrys',
method: 'GET'}
),
reader: countryReader,
autoLoad: true
}),
displayField:'country_name',
valueField:'country_id',
triggerAction:'all',
mode:'local',
listeners:{
select:{
fn:function(combo, value) {
var modelCmp = Ext.getCmp(this.town_name_id);
alert(this.town_name_id);
modelCmp.setValue('');
modelCmp.getStore().proxy.setUrl('../lib/getRFB.php');
modelCmp.store.reload({
params: { 'country_id': this.getValue(),rfb_type: 'towns' }
});
}
}
},
hiddenName:'country_id',
initComponent: function() {comboCountryClass.superclass.initComponent.call(this);}})
И город комбо
comboTownClass = Ext.extend(Ext.form.ComboBox, {
fieldLabel:'town',
displayField:'town_name',
valueField:'town_id',
hiddenName:'town_id',
anchor: '95%',
id:this.town_name_id || 'youuuu',
store: new Ext.data.Store({
proxy: new Ext.data.HttpProxy(
{url: 'lib/handlers/orgHandler.php?action=read&towns=true',
method: 'GET'}
),
reader: townReader
}),
triggerAction:'all',
mode:'local',
initComponent: function() {comboTownClass.superclass.initComponent.call(this);}})
new comboTownClass ({town_name_id: 'townFormSearch'})
новый comboCountryClass ({town_name_id: 'townFormSearch'})