设置vaadin表高度以适合内容

时间:2012-08-20 07:04:29

标签: css vaadin

我在项目中使用CustomLayout来分隔UI对象及其样式。

表格有问题。

我定义了一个div,我希望将表格的高度设置为div的高度。

哪种方式最好?

我想:

table.setsizeFull() ;
table.setPageLength(0);

在代码中,但结果不是我想要的。 我希望桌子在div的尺寸中全尺寸,无论是否有元素。

有什么建议吗?

1 个答案:

答案 0 :(得分:10)

我正在解决一个类似的问题:我想要一个表增长,因为我添加了行。我不关心它的确切高度,只要它显示所有数据行,并随着我添加行而增长。我还希望桌子总是在底部显示一些额外的空间。

这里的核心思想是我做了三件事:

  • 请勿为表格致电setHeight()
  • 我使用setPageLength()按行来定义表高度 - 表格应该是多少行。
  • 我在我调整大小的元素上调用了requestRepaint()。如果我调整了列元素的大小,我在列元素上调用它。如果我调整了表格的大小,我就把它称为桌面。

这是一个通用的代码示例,展示了我是如何解决这个问题的。我的代码不完整,但它可能会帮助您开始。

public class MyClass extends Table {

    public MyClass(...)
    {
        this.setWidth("100%"); // fill parent <td>'s width, allows draggable sizing.
        // note: do NOT setHeight().

        setupColumns(); // details not shown here
        setupBehavior(); // details not shown (listeners, etc)
        addDataToTable(); // details not shown

        adjustHeight();
    }

    // I also have a function to add rows to the table when 
        // a button is clicked.  That function calls adjustHeight() (shown below).

    public void adjustHeight()
    {
        this.setPageLength(this.getItemIds().size() + 1);
        this.requestRepaint();
    }
}

[EDIT / FOLLOW-UP]我发现如果使用setColumnExpandRatio()(动态列宽),使用此方法往往会导致在表上呈现不必要的滚动条。所以就像单挑一样,如果你使用我上面展示的技巧,你应该使用固定宽度的列(setColumnWidth())。