1

在 vaadin7 中,我使用 GeneratedPropertyContainer 来执行此操作,例如添加行号:

        wrappedContainer = new GeneratedPropertyContainer(_container);
        wrappedContainer.addGeneratedProperty("#", 
                new PropertyValueGenerator<Integer>() {

                    @Override
                    public Integer getValue(Item item, Object itemId, Object propertyId) {
                        return (int) _container.indexOfId(itemId) + 1;
                    }

                    @Override
                    public Class<Integer> getType() {
                        return java.lang.Integer.class;
                    }
                }
        );

        setContainerDataSource(wrappedContainer);

在 vaadin8 中,由于 GeneratedPropertyContainer 已被弃用,我尝试这样做: grid.addColumn((v)->((List)_container.getData().getItems()).indexOf(v)+1);

但是索引是静态的,当我对行进行升序和降序排序时,行号也在移动。

我需要的是第一行是第 1 行,最后一行是第 N 行,无论我如何对行进行排序。

谢谢。

4

1 回答 1

2

不幸的是,据我所知,没有开箱即用的简单解决方案。但是,您可以执行以下代码:

Grid<MyBean> grid = new Grid<>();
grid.setDataProvider(new RowIndexDataProviderWrapper<>(DataProvider.ofItems(new MyBean("Item 1"), new MyBean("Item 2"), new MyBean("Item 3"))));
grid.addColumn(MyBean::getRowIndex).setCaption("#");
grid.addColumn(MyBean::getName).setCaption("Name");

public interface RowIndexAware {
    void setRowIndex(int rowIndex);
    int getRowIndex();
}

public class MyBean implements RowIndexAware {
    // implement the interface (e.g. store row index in field)
    // and add your bean properties
}

public class RowIndexDataProviderWrapper<T extends RowIndexAware, F> implements DataProvider<T, F> {

    private DataProvider<T, F> wrapped;

    public RowIndexDataProviderWrapper(DataProvider<T, F> wrapped) {
        this.wrapped = wrapped;
    }

    // delegate all methods to be implemented for DataProvider interface
    // to wrapped DataProvider with the exception of "fetch":

    @Override
    public Stream<T> fetch(Query<T, F> query) {
        List<T> result = wrapped.fetch(query).collect(Collectors.toCollection(ArrayList::new));
        for (int i = 0; i < result.size(); i++) {
            result.get(i).setRowIndex(query.getOffset() + i);
        }
        return result.stream();
    }

}

这个想法是在 DataProvider 中获取行时获取行索引并将它们存储在您的 bean 中。

于 2017-06-11T09:23:09.237 回答