CellTable KeyboardSelectionPolicy错误

时间:2013-10-04 19:09:40

标签: gwt celltable gwt-celltable

我有一个CellTable,并希望将键盘选择策略设置为KeyboardSelectionPolicy.BOUND_TO_SELECTION。但是,似乎第一行中TextCell的第一次单击并未按预期完全选择行。为了说明,它看起来像这样: enter image description here 而不是这个: enter image description here

所有后续点击都会按预期选择行,键盘导航也是如此。此外,如果第一次点击位于NumberCell或任何其他行的TextCell,则选择按预期工作。问题只出现在第一行TextCell上的第一次点击。

要重现,请考虑以下示例代码:

public class WebApp implements EntryPoint {

    private static class Model {
        private final int num;
        private final String name;
        public Model(String name, int num) {
            super();
            this.name = name;
            this.num = num;
        }
        public String getName() {
            return name;
        }
        public int getNum() {
            return num;
        }
    }

    @Override
    public void onModuleLoad() {

        final CellTable<Model> table = new CellTable<Model>();
        table.setWidth("100%", true);  // Truncate cell contents as needed.

        // Causes bug on first row first click TextCell selection.
        table.setKeyboardSelectionPolicy(KeyboardSelectionPolicy.BOUND_TO_SELECTION);

        // Add a column to show the name.
        TextCell textCell = new TextCell() {
            @Override
            public Set<String> getConsumedEvents() {
                return Sets.newHashSet(BrowserEvents.CLICK);
            }
        };
        Column<Model, String> termColumn = new Column<Model, String>(new TextCell()) {
            @Override
            public String getValue(Model entry) {
                return entry.getName();
            }
        };
        termColumn.setHorizontalAlignment(HasHorizontalAlignment.ALIGN_LEFT);
        table.addColumn(termColumn);

        // Add a column to show the num.
        Column<Model, Number> numberColumn = new Column<Model, Number>(new NumberCell()) {
            @Override
            public Number getValue(Model object) {
                return object.getNum();
            }
        };
        numberColumn.setHorizontalAlignment(HasHorizontalAlignment.ALIGN_RIGHT);
        table.addColumn(numberColumn);

        // Add a selection model to handle user selection.
        final SingleSelectionModel<Model> selectionModel = new SingleSelectionModel<Model>();
        table.setSelectionModel(selectionModel);

        // Data.
        ArrayList<Model> entries = buildEntries();

        // Set the total row count. This isn't strictly necessary, but it affects
        // paging calculations, so its good habit to keep the row count up to date.
        table.setRowCount(entries.size(), true);

        // Push the data into the widget.
        table.setRowData(0, entries);

        // Add it to the root panel.
        RootLayoutPanel rootLayoutPanel = RootLayoutPanel.get();
        rootLayoutPanel.getElement().getStyle().setWidth(50, Unit.PCT);
        rootLayoutPanel.getElement().getStyle().setHeight(50, Unit.PCT);
        rootLayoutPanel.getElement().getStyle().setProperty("margin", "auto");
        rootLayoutPanel.add(table);
    }

    private ArrayList<Model> buildEntries() {
        ArrayList<Model> l = Lists.newArrayList();

        for (int i = 0; i < 10; ++i) {
            l.add(buildEntry());
        }

        return l;
    }

    private int currNum = 0;
    private char currChar = 'a' - 1;
    private Model buildEntry() {
        int num = currNum++;
        String term = Character.toString(++currChar);
        for (int i = 0; i < 25; i++) {
            term += currChar;
        }
        return new Model(term, num);
    }
}

这表现在Chrome,FF,IE上。感谢任何帮助。谢谢。

0 个答案:

没有答案