我们可以动态更改 GWT 引导程序 3 按钮单元格图标吗?



我有一个GWT引导3按钮作为使用IconType和ButtonType创建的ButtonCell:

public abstract class ButtonColumn<T> extends Column<T, String> {
    public ButtonColumn(IconType iconType, ButtonType buttonType) {
        this(new ButtonCell(buttonType, iconType));
    }
}

因此,当我创建按钮时,我确实

new ButtonColumn<Object>(IconType.PLAY, ButtonType.SUCCESS) {
  @Override
  public void onClick(Object obj) {
    doStuff(obj);
  }
};

我想更改我的按钮图标类型点击。有可能实现吗? 我可以创建一个扩展 GWT 图标类型枚举的自定义图标类型吗?我想放一个动画图标(如加载图标(。

好吧,您不能连续更改按钮的图标,尤其是当您使用已指定的图标创建整个列时。但是你可以redraw()一行,这可能是实现你想要的一种方式。

我使用 AbstractCell 来渲染一个按钮和 onBrowserEvent:

  • 首先创建一个consumedEvents参数中包含ClickEvent的抽象单元格
  • render() 方法中,根据单击状态呈现按钮
  • onBrowserEvent() 方法中更改单击状态并重新呈现行

单击状态最好保留在表的基础数据类型中,以便它可用于每一行。

这是一个完整的工作示例代码:

final CellTable<TableType> table = new CellTable<TableType>();
AbstractCell<TableType> buttonCell = new AbstractCell<ButtonCellTest.TableType>(ClickEvent.getType().getName()) {
    @Override
    public void render(Context context, TableType value, SafeHtmlBuilder sb) {
        Button button = new Button();
        button.setType(ButtonType.SUCCESS);
        button.setSize(ButtonSize.SMALL);
        button.add(new Icon(value.isClicked() ? IconType.CHECK : IconType.TIMES));
        sb.append(SafeHtmlUtils.fromTrustedString(button.toString()));
    }
    @Override
    public void onBrowserEvent(Context context, Element parent, TableType value, NativeEvent event, ValueUpdater<TableType> valueUpdater) {
        value.setClicked(!value.isClicked());
        // ... do stuff...
        table.redrawRow(context.getIndex());
    }
};
table.addColumn(new Column<TableType, TableType>(buttonCell) {
    @Override
    public TableType getValue(TableType object) {
        return object;
    }
});
ArrayList<TableType> rowData = new ArrayList<TableType>();
rowData.add(new TableType("row 1"));
rowData.add(new TableType("row 2"));
...
table.setRowData(rowData);

示例表的数据类型保持单击状态:

public class TableType {
    String text;
    boolean clicked = false;
    public TableType(String text) {
        this.text = text;
    }
    public String getText() {
        return text;
    }
    public boolean isClicked() {
        return clicked;
    }
    public void setClicked(boolean clicked) {
        this.clicked = clicked;
    }
}

至于扩展IconType枚举 - 不,你不能在 Java 中扩展枚举。例如,请参阅此问题:枚举可以子类化以添加新元素吗?

您可以尝试添加自己的CSS类,但这应该作为另一个问题提出以获得准确的答案。

最新更新