アプリケーションでExtJを使用していますが、一意の列を持つグリッドがあります。この列にはコンボボックスであるエディターがあるため、グリッドセルをクリックすると、1つのコンボボックスが表示されます。ただし、クリックしてグリッドセルの値を編集すると、オブジェクトの名前が表示されますが、セルの外側をクリックすると、グリッドにレンダリングされる値はオブジェクトのIDになります。
私がアイテムを選ぶとき:
コンボボックスの外側をクリックすると:
私のコード:
Ext.define('ComboBoxDoenca', {
extend : 'Ext.form.ComboBox',
displayField: 'nome',
editable: false,
width: 300,
valueField: 'id',
listeners:{
render: function(combo){
combo.store = Ext.create('ComboStore').load();
}
}
});
グリッドコード:
Ext.define('GridDoenca', {
extend : 'Ext.grid.Panel',
title: 'Doenças',
alias : 'widget.doencaList',
id: 'gridDoenca',
height: 150,
plugins: [Ext.create('Ext.grid.plugin.CellEditing', {
clicksToEdit: 1
})],
initComponent : function() {
var comboDoenca = Ext.create('Hemisphere.view.fungicida.ComboBoxDoenca');
me = this;
Ext.apply(this, {
dockedItems : [ {
xtype : 'toolbar',
dock : 'top',
items : [ {
text : 'Add Doença',
icon : Webapp.icon('add1.png'),
iconAlign : 'top',
action : 'addDoenca'
}]
} ]
});
this.columns = [ {
header : 'ID',
dataIndex : 'id',
hidden: true
},{
header : 'Doença',
dataIndex : 'id',
editor: comboDoenca,
flex: 1
}];
this.callParent(arguments);
}
});
誰かが私を助けることができますか?