我开始使用GWT,但我遇到了一些困难。我试图在一个SimpleLayout中加载一个复合文件,但是什么也没有出现。它不会抛出任何类型的错误,所以我不知道去哪里看。
我的入口点如下所示:
import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;
public class AppDriver implements EntryPoint{
private ExampleShell shell;
@Override
public void onModuleLoad() {
shell = new ExampleShell();
RootPanel.get().add(shell);
}
}这个类可以很好地工作,并加载如下所示的ExampleShell类:
import com.google.gwt.core.client.GWT;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.Widget;
import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.user.client.ui.Button;
import com.ohapp.helloweb.client.contacts.ContactsUi;
import com.google.gwt.user.client.ui.SimplePanel;
public class ExampleShell extends Composite {
private static ExampleShellUiBinder uiBinder = GWT
.create(ExampleShellUiBinder.class);
@UiField Button btnHome;
@UiField Button btnContacts;
@UiField SimplePanel contentPanel;
interface ExampleShellUiBinder extends UiBinder<Widget, ExampleShell> {
}
public ExampleShell() {
initWidget(uiBinder.createAndBindUi(this));
btnHome.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
//TODO
}
});
btnContacts.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
try{
SimplePanel panel = ExampleShell.this.getContentPanel();
panel.clear();
ContactsUi contacts = new ContactsUi();
panel.add(contacts);
} catch (Exception ex){
System.out.println(ex.getStackTrace());
}
}
});
}
public SimplePanel getContentPanel(){
return this.contentPanel;
}
public void setContentPanel(SimplePanel contentPanel){
this.contentPanel = contentPanel;
}
}我的ExampleShell.ui.xml看起来像这样:
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
xmlns:g="urn:import:com.google.gwt.user.client.ui">
<ui:style>
.important {
font-weight: bold;
}
</ui:style>
<g:DockLayoutPanel>
<g:north size="100.0">
<g:FlowPanel>
<g:Image width="80px" height="80px"/>
<g:Button ui:field="btnHome">Home</g:Button>
<g:Button ui:field="btnContacts">Contacts</g:Button>
</g:FlowPanel>
</g:north>
<g:center>
<g:SimplePanel ui:field="contentPanel"/>
</g:center>
</g:DockLayoutPanel>
</ui:UiBinder> 在此之前,一切都很正常。然而,当按钮btnContacts被按下时,它应该将ContactsUi (扩展复合)添加到布局中,但我什么也看不到。它也不会抛出错误。
ContactsUi类如下所示:
import com.google.gwt.core.client.GWT;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.Widget;
public class ContactsUi extends Composite {
private static ContactsUiBinder uiBinder = GWT
.create(ContactsUiBinder.class);
interface ContactsUiBinder extends UiBinder<Widget, ContactsUi> {
}
public ContactsUi() {
initWidget(uiBinder.createAndBindUi(this));
}
}ContactsUi.ui.xml如下所示:
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
xmlns:g="urn:import:com.google.gwt.user.client.ui">
<ui:style>
.backGroundPanel {
background-color: #F60;
}
</ui:style>
<g:DockLayoutPanel styleName="{style.backGroundPanel}">
<g:center>
<g:FlowPanel>
<g:Label text="New Label" />
<g:Button>Contacts</g:Button>
</g:FlowPanel>
</g:center>
</g:DockLayoutPanel>
</ui:UiBinder> 我做错了什么?
诚挚的问候。
发布于 2013-07-13 07:20:19
必须将实现RequiresResize的小部件放入实现ProvidesResize的小部件中,或者给它一个明确的大小(最好是以像素为单位)。
在本例中,因为组合的根小部件是DockLayoutPanel,所以应该使用ResizeComposite而不是Composite,使用RootLayoutPanel而不是RootPanel。
请参阅https://code.google.com/p/google-web-toolkit/issues/detail?id=5874和“在没有RootLayoutPanel的情况下使用LayoutPanel”食谱http://www.gwtproject.org/doc/latest/DevGuideUiPanels.html#Recipes (您也可以在此页面中阅读有关RequiresResize和ProvidesResize的更多信息)
https://stackoverflow.com/questions/17621387
复制相似问题