我有一个小部件(Main.java),它封装了funcionality并实现了Async Provider模式以进行代码分割。另外,我使用Prefetching模式,以便浏览器在加载欢迎屏幕后立即下载代码。
问题出现在IE8中。如果我在不进行预取的情况下使用主窗口小部件,一切都很好。但是,如果我先预取然后尝试使用te主窗口小部件,则浏览器仅显示主窗口小部件使用的DockLayoutPanel的中心面板。 在Firefox中一切正常。
以下是代码:
//BugTest.java
package com.bugtest.clearadd.client;
import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.user.client.rpc.AsyncCallback;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.PopupPanel;
import com.google.gwt.user.client.ui.RootLayoutPanel;
import com.google.gwt.user.client.ui.RootPanel;
public class BugTest implements EntryPoint {
@Override
public void onModuleLoad() {
Button prefetchButton = new Button("Prefetch!");
prefetchButton.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
Main.getInstance(new AsyncCallback<Main>() {
@Override
public void onSuccess(Main result) {
PopupPanel popupPanel = new PopupPanel(true);
popupPanel
.setWidget(new Label("Prefetching finished!"));
popupPanel.center();
}
@Override
public void onFailure(Throwable caught) {
// TODO Auto-generated method stub
}
});
}
});
Button switchButton = new Button("Switch!");
switchButton.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
Main.getInstance(new AsyncCallback<Main>() {
@Override
public void onSuccess(Main result) {
RootPanel.get().clear();
RootLayoutPanel.get().add(result);
}
@Override
public void onFailure(Throwable caught) {
// TODO Auto-generated method stub
}
});
}
});
FlowPanel flowPanel = new FlowPanel();
flowPanel.add(new Label("Bug test!"));
flowPanel.add(prefetchButton);
flowPanel.add(switchButton);
RootPanel.get().add(flowPanel);
}
}
//Main.java
package com.bugtest.clearadd.client;
import com.google.gwt.core.client.GWT;
import com.google.gwt.core.client.RunAsyncCallback;
import com.google.gwt.dom.client.Style.Unit;
import com.google.gwt.user.client.rpc.AsyncCallback;
import com.google.gwt.user.client.ui.DockLayoutPanel;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.ResizeComposite;
public class Main extends ResizeComposite {
private static Main instance = null;
public static void getInstance(final AsyncCallback<Main> callback) {
GWT.runAsync(new RunAsyncCallback() {
@Override
public void onSuccess() {
if (instance == null) {
instance = new Main();
}
callback.onSuccess(instance);
}
@Override
public void onFailure(Throwable reason) {
callback.onFailure(reason);
}
});
}
private Main() {
DockLayoutPanel dockLayoutPanel = new DockLayoutPanel(Unit.EM);
dockLayoutPanel.addNorth(new Label("North!"), 7);
dockLayoutPanel.addWest(new Label("West!"), 15);
dockLayoutPanel.add(new Label("Center! :D"));
initWidget(dockLayoutPanel);
}
}
有谁知道它可能是什么?提前谢谢。
编辑:我注意到如果我将DockLayoutPanel单位更改为PX,一切正常。这是一个错误还是我遗失了什么?再次感谢。 :P
答案 0 :(得分:0)
我意识到这个问题与Code Splitting无关。我删除了GWT.runAsync函数,同样的问题仍然出现了。 问题更可能与DockLayoutPanel,单元EM和设计模式有关,因此这个问题应该在另一个问题中发布。 更具体地说,我改变了Async Provider模式的单一模式,问题仍然出现了。 而且,如果我将单位从EM更改为PX,问题似乎就解决了。 不管怎样,谢谢!
编辑:我在这篇文章中发布了这个问题的新特征: https://stackoverflow.com/questions/3313981/gwt-ie8-problem-with-composite-over-docklayoutpanel-the-unit-em-and-the-single