gwt 列的通用 InputCell(更改单元格类型或在创建列构造函数之前知道 属性 的单元格类型)
Generic InputCell for gwt Column (Change Cell-type or know Property's Cell-type before creating Column-constructor)
在我们现有的 GWT 项目中,我们有一个包含多个单元格的 table。我们使用 com.google.gwt.user.cellview.client.Column.Column
作为此 table 的列。这是我们当前的代码:
private void addColumns() {
// label column
final Column<Property, String> labelColumn = new Column<Property, String>(new TextCell()) {
@Override
public String getValue(final Property object) {
return object.getPdf().getName();
}
};
this.datagrid.addColumn(labelColumn, "Label");
this.datagrid.setColumnWidth(labelColumn, 40, Unit.PX);
// value column
final Column<Property, String> valueColumn = new Column<Property, String>(new TextInputCell()) {
@Override
public String getValue(final Property object) {
return object.getValue();
}
};
valueColumn.setFieldUpdater(new FieldUpdater<Property, String>() {
@Override
public void update(final int index, final Property object, final String value) {
final Property existingObject = containsObject(object);
if (existingObject != null) {
existingObject.setValue(value);
} else {
// else add the object to the "editedFields" list
object.setValue(value);
UserDefinedFieldsValuesDiv.this.editedProperties.add(object);
}
}
});
this.datagrid.addColumn(valueColumn, "Waarde");
this.datagrid.setColumnWidth(valueColumn, 40, Unit.PX);
}
这将生成如下所示的 table:
目前一切都是 TextInputCell
,但我想根据列的类型更改它。所以如果是日期,我想要一个DatePickerCell等
在以下代码段中:
// value column
final Column<Property, String> valueColumn = new Column<Property, String>(new TextInputCell()) {
@Override
public String getValue(final Property object) {
return object.getValue();
}
};
它给出了一个 new TextInputCell()
作为参数,但只有在该列中我才能使用 object.getType().name().equals(Type.DATE.name())
检索类型。我查看了 Column
的源代码,但只有 getCell
方法,没有 setCell
。有没有一种方法可以更改列的单元格类型,或者有一种方法可以预先知道单元格的类型(我可以从 Property
中检索)?
PS: 这是我第一天使用GWT,所以有些东西可能还不是很熟悉。
编辑:
所以我想要实现的是这样的:
// value column
AbstractCell cell = new TextInputCell();
Property propertyISomehowRetrieved = ...;
if (propertyISomehowRetrieved.getType().name().equals(Type.DATE.name())){
cell = new DatePickerCell();
} else if(propertyISomehowRetrieved.getType().name().equals(Type.NUMERIC.name())){
cell = new NumberCell();
} else if(propertyISomehowRetrieved.getType().name().equals(Type.BOOLEAN.name())){
cell = new CheckboxCell();
}
final Column<Property, String> valueColumn = new Column<Property, String>(cell) {
@Override
public String getValue(final Property object) {
return object.getValue();
}
};
但是我该如何检索这个 属性?
每列只能使用一个单元格。这就是单元格类型被传递到构造函数并且不能更改的原因。正如示例中所示,您不能对不同的行使用不同的单元格。
当您构建具有多个列的DataGrid 时,您可以根据该DataGrid 将要显示的对象的属性添加不同的列。例如,如果您的对象有两个属性 "Date" 和 "Title",您可以使用 DatePickerCell 和 TextInputCell 添加两列。由于这是 您的 对象,您在构建 DataGrid 之前知道属性的类型,因此您可以添加正确的列并在构建时选择所需的单元格类型。
在我们现有的 GWT 项目中,我们有一个包含多个单元格的 table。我们使用 com.google.gwt.user.cellview.client.Column.Column
作为此 table 的列。这是我们当前的代码:
private void addColumns() {
// label column
final Column<Property, String> labelColumn = new Column<Property, String>(new TextCell()) {
@Override
public String getValue(final Property object) {
return object.getPdf().getName();
}
};
this.datagrid.addColumn(labelColumn, "Label");
this.datagrid.setColumnWidth(labelColumn, 40, Unit.PX);
// value column
final Column<Property, String> valueColumn = new Column<Property, String>(new TextInputCell()) {
@Override
public String getValue(final Property object) {
return object.getValue();
}
};
valueColumn.setFieldUpdater(new FieldUpdater<Property, String>() {
@Override
public void update(final int index, final Property object, final String value) {
final Property existingObject = containsObject(object);
if (existingObject != null) {
existingObject.setValue(value);
} else {
// else add the object to the "editedFields" list
object.setValue(value);
UserDefinedFieldsValuesDiv.this.editedProperties.add(object);
}
}
});
this.datagrid.addColumn(valueColumn, "Waarde");
this.datagrid.setColumnWidth(valueColumn, 40, Unit.PX);
}
这将生成如下所示的 table:
目前一切都是 TextInputCell
,但我想根据列的类型更改它。所以如果是日期,我想要一个DatePickerCell等
在以下代码段中:
// value column
final Column<Property, String> valueColumn = new Column<Property, String>(new TextInputCell()) {
@Override
public String getValue(final Property object) {
return object.getValue();
}
};
它给出了一个 new TextInputCell()
作为参数,但只有在该列中我才能使用 object.getType().name().equals(Type.DATE.name())
检索类型。我查看了 Column
的源代码,但只有 getCell
方法,没有 setCell
。有没有一种方法可以更改列的单元格类型,或者有一种方法可以预先知道单元格的类型(我可以从 Property
中检索)?
PS: 这是我第一天使用GWT,所以有些东西可能还不是很熟悉。
编辑:
所以我想要实现的是这样的:
// value column
AbstractCell cell = new TextInputCell();
Property propertyISomehowRetrieved = ...;
if (propertyISomehowRetrieved.getType().name().equals(Type.DATE.name())){
cell = new DatePickerCell();
} else if(propertyISomehowRetrieved.getType().name().equals(Type.NUMERIC.name())){
cell = new NumberCell();
} else if(propertyISomehowRetrieved.getType().name().equals(Type.BOOLEAN.name())){
cell = new CheckboxCell();
}
final Column<Property, String> valueColumn = new Column<Property, String>(cell) {
@Override
public String getValue(final Property object) {
return object.getValue();
}
};
但是我该如何检索这个 属性?
每列只能使用一个单元格。这就是单元格类型被传递到构造函数并且不能更改的原因。正如示例中所示,您不能对不同的行使用不同的单元格。
当您构建具有多个列的DataGrid 时,您可以根据该DataGrid 将要显示的对象的属性添加不同的列。例如,如果您的对象有两个属性 "Date" 和 "Title",您可以使用 DatePickerCell 和 TextInputCell 添加两列。由于这是 您的 对象,您在构建 DataGrid 之前知道属性的类型,因此您可以添加正确的列并在构建时选择所需的单元格类型。