如何在Vaadin中添加Grid中的按钮

her*_*fiq 9 vaadin vaadin7

嗨我尝试在vaadin中的网格中添加按钮,但它打印按钮对象上的引用.

Grid statementEnquiriesList = new Grid();
statementEnquiriesList.addColumn("", Button.class);
        statementEnquiriesList.addColumn("DATE/TIME", String.class);
        statementEnquiriesList.addColumn("TRANSACTION ID", String.class);
        statementEnquiriesList.addColumn("FROM", String.class);

// historyList is an array object
for (int i = 0; i < historyList.size(); i++)
{
    HistoryList recordObj = historyList.get(i);
    Button addBtn = new Button();
    addBtn.setCaption("Add");
    statementEnquiriesList.addRow(addBtn , recordObj.getDate(), recordObj.getTransactionId(), recordObj.getFrom());
}
Run Code Online (Sandbox Code Playgroud)

我怎样才能在此打印"添加"标题

在此输入图像描述

Pir*_*ica 7

您不能在Vaadin 7中直接使用网格中的组件.您必须使用ButtonRenderer来呈现按钮

RendererClickListener ownerClickListener = new RendererClickListener() {

    private static final long serialVersionUID = 1L;

    @Override
    public void click(RendererClickEvent event) {
        //Someone clicked button
    }
};
ButtonRenderer ownerRenderer = new ButtonRenderer(ownerClickListener, "");
grid.getColumn("ownerName").setRenderer(ownerRenderer);
Run Code Online (Sandbox Code Playgroud)

但是您可以在Vaadin 8中使用组件,请参阅Vaadin 8中的网格组件.

我正在使用Vaadin 7和ButtonRenderer对我不满意,因为没有办法将FontIcon添加到按钮,并且无法将其作为HTML插入.相反,我使用了组件渲染器插件.这是我如何使用它:

Grid grid = new Grid();
BeanItemContainer<EventChange> dataSource = //... primary data source
GeneratedPropertyContainer dataSource2 = new GeneratedPropertyContainer(dataSource);
grid.setContainerDataSource(dataSource2);
dataSource2.addGeneratedProperty("ownerWithButton", new PropertyValueGenerator<Component>() {

        private static final long serialVersionUID = 1L;

        @Override
        public Component getValue(Item item, Object itemId, Object propertyId) {
            ClickListener ownerClickListener = new ClickListener() {

                private static final long serialVersionUID = 1L;
                @Override
                public void buttonClick(ClickEvent event) {
                    // do something, user clicked button for itemId
                }
            };
            Button button = new Button(FontAwesome.USER);
            button.addClickListener(ownerClickListener);
            return button;
        }

        @Override
        public Class<Component> getType() {
            return Component.class;
        }
    });
grid.setColumns("ownerWithButton", /*and rest of your columns*/);
grid.getColumn("ownerWithButton").setRenderer( new ComponentRenderer());
Run Code Online (Sandbox Code Playgroud)


Bas*_*que 6

Vaadin 8.1 - 网格中的组件

Vaadin 8.1现在有一个内置ComponentRenderer显示按钮或其他组件,包括你自己在网格中的自定义组件.

在" 新功能"页面上查看第一项"网格中的组件" .

示例:向网格添加标签.

grid.addColumn(
    person -> new Label( person.getFullName() ) ,
    new ComponentRenderer()
).setCaption( "Full Name" ) 
Run Code Online (Sandbox Code Playgroud)