我使用GXT2.2.3创建了EditorGrid,所需的每一件事都是over.But,我需要根据一个单元格中的值禁用和启用一些单元格。但是我找到了不适合我的解决方案,我在Sencha,coderanch和其他一些论坛上问过,但我还是没有找到解决方案。
现在,我决定将其迁移到GXT3.0.1。
我需要一个EditableGrid,需要根据另一个Cell.Please中的值禁用和启用单元格编辑,建议在GXT3.0.1中哪个网格适合这样做,以及如何迁移到GXT2.2.3到GXT3.0.1。
发布于 2014-04-16 11:26:39
我只是通过使用CSS来解决这个问题。相反,考虑禁用和启用单元格,我只是隐藏和显示使用CSS的单元格。下面是我的代码,它可以帮助我达到这个要求。
GridCellRenderer<AttendanceCaseCreationModel> checkinRenderer=new GridCellRenderer<AttendanceCaseCreationModel>() {
@Override
public Object render(AttendanceCaseCreationModel model, String property,
ColumnData config, int rowIndex, int colIndex,
ListStore<AttendanceCaseCreationModel> store,
Grid<AttendanceCaseCreationModel> grid) {
String color="pink";
if(eventcombo.getValue()!=null){
if(eventcombo.getRawValue().equalsIgnoreCase("Forgot To Checkin") ||
eventcombo.getRawValue().equalsIgnoreCase("Mark/Modify Attendance")){
color="pink";
}
else{
config.style=config.style+ ";visibility: hidden;";
}
}
config.style=config.style+ ";background-color:" + color + ";";
config.style=config.style+ ";display: block;";
Object value = model.get(property);
return value;
}
};发布于 2014-04-12 10:47:07
我不使用gxt 2.x.x。我的朋友试着从2迁移到3,他使用2和3并行。因此,他开始用gxt3构建一个新页面,因为如果将它们混合在一起,布局可能会遇到很大的问题!如果您想使用gxt3,您应该这样做:
//Create grid
Grid<Plant> grid = new Grid(...);
//Create editable grid
GridEditing<Plant> editing = new GridInlineEditing<Plant>(editableGrid);
//add first editing column
TextField watchField = new TextField();
TextField targerField = new TextField();
watchField.addChangeHandler(new ChangeHandler() {
@Override
public void onChange(ChangeEvent event) {
if(smtng) targerField.disable();
else targetField.enable();
}
});
editing.addEditor(cc1, watchField);
editing.addEditor(cc2, targetField);所以我认为这对你有帮助。
https://stackoverflow.com/questions/23025115
复制相似问题