java - GWT TabLayoutPanel 无法正常显示

标签 java gwt

我必须扩展一个给定的 GWT 项目(我们称之为 X),并希望添加一个窗口来可视化我的东西。由于我是 GWT 新手,我创建了一个测试项目并尝试创建 TabLayoutPanel。在此测试项目中,TabLayoutPanel 按其应有的方式显示,但在 X 中却并非如此:

http://abload.de/img/tablayoutpanelc1svz.png

TabLayoutPanel 的代码来自 GWT 教程

uiBinder

<!-- HelloWidgetWorld.ui.xml -->
<ui:UiBinder xmlns:ui='urn:ui:com.google.gwt.uibinder' xmlns:g='urn:import:com.google.gwt.user.client.ui'>
<g:TabLayoutPanel ui:field='tabLayoutPanel' barUnit='EM' barHeight='3'>
    <g:tab>
        <g:header size='7'><b>HTML</b> header</g:header>
        <g:Label>able</g:Label>
    </g:tab>
    <g:tab>
        <g:customHeader size='7'>
            <g:Label>Custom header</g:Label>
        </g:customHeader>
        <g:Label>baker</g:Label>
    </g:tab>
</g:TabLayoutPanel>
</ui:UiBinder>

Java

public class HelloWidgetWorld extends Composite 
{
    interface IuiBinder extends UiBinder<Widget, HelloWidgetWorld> {}
    private static IuiBinder uiBinder = GWT.create(IuiBinder.class);

    @UiField TabLayoutPanel tabLayoutPanel;

    public HelloWidgetWorld()
    {
        initWidget(uiBinder.createAndBindUi(this));
    }   
}

在我的测试项目中使用它的代码是

public class Test implements EntryPoint 
{
    private Window HelloWidgetWorldWindow;
    public void onModuleLoad() 
    {
        RootLayoutPanel.get().add(new HelloWidgetWorld());
    }
}

通过尝试缩小问题范围,我最终在 X 中使用了完全相同的代码,但仍然遇到问题。所以我将这段代码复制到X中,所以onModuleLoad()代码是相同的。我还将测试项目中的 css 和 html 文件复制到 X,但面板看起来仍然不正常。

既然代码现在都是一样的,它只能是其他项目文件或设置中的东西吗?

现在花了 5 个小时修复这个问题,但没有成功,我真的希望你能帮助我!

/编辑

我现在正在尝试重建给定的项目 X,从一个新项目开始,然后导入代码、库、js、css、*.xml 等。每一步之后我都会检查我的最小示例是否有效。也许这样我就可以追踪哪个组件破坏了 TabLayoutPanel 可视化。我将在这里更新结果。

最佳答案

  1. 在任何小部件(垂直/水平/...)面板中添加 TabLayoutPanel

  2. 选项卡不会出现,因为 TabLayoutPanel 没有任何高度或宽度(主要是百分比不起作用,您必须使用不同的单位)。

  3. 检查您正在使用 GWT 2.5 中的新布局面板之一

关于java - GWT TabLayoutPanel 无法正常显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21969988/

相关文章:

Java - 复制构造函数 - java.lang.NullPointerException

java - 为每个Web应用程序(上下文)保存一个存储库是更好还是通过JNDI或类似技术共享一个公共(public)实例更好?

java - 在长期服务器应用程序中有效地缓存和更新当前日期

GWT 的 java.lang.IllegalCastException

java - ArrayList越界错误

java - 将 draftCompile 传递给 IntelliJ IDEA 的 GWT 编译器

javascript - GWT 中是否有任何通知将要下载哪个片段

java - JSONParser 类型没有可用的源代码

gwt - Tomcat 6 : HTTPS times out but HTTP works (Maybe GWT issue? )

java - 适用于 Windows 32 位和 64 位 JavaFX 应用程序的单一安装程序