17

我想创建一个组件来装饰它的孩子,例如:

mycomponent.ui.xml:

<g:FlowPanel addStyleNames="myStyle">
    <!-- how can i render children ? -->
</g:FlowPanel>

然后其他人可以使用:

<myapp:mycomponent>
    <g:Label>Decorated child</g:Label>
</myapp:mycomponent>

如何在 uibinder 中渲染孩子?(或者在Java中,如果我必须的话)

4

2 回答 2

33

让我们MyComponent实现HasWidgets添加/删除子小部件的接口。

看起来MyComponent.ui.xml很简单

<g:FlowPanel ui:field="main" />

当您将指定的方法委托给 indHasWidgetsFlowPanel

public class MyComponent extends Composite implements HasWidgets {

    private static MyComponentUiBinder uiBinder = GWT.create(MyComponentUiBinder.class);

    interface MyComponentUiBinder extends UiBinder<Widget, MyComponent> {}

    @UiField
    FlowPanel main;

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

    @Override
    public void add(Widget w) {
        main.add(w);
    }

    @Override
    public void clear() {
        main.clear();
    }

    @Override
    public Iterator<Widget> iterator() {
        return main.iterator();
    } 

    @Override
    public boolean remove(Widget w) {
        return main.remove(w);
    }
}

打电话

<M:MyComponent>
    <g:Label text="some text" />
</M:MyComponent>

将以这种方式工作。

于 2010-11-14T09:14:46.393 回答
1

使用这个 XML:

<myapp:mycomponent>
    <g:Label>Decorated child</g:Label> 
</myapp:mycomponent>

将实例化MyComponent然后调用MyComponent.add(label). 您所要做的就是.add(..)在您的类中覆盖MyComponent并应用您想要传递组件的任何样式。

于 2010-11-13T23:38:24.193 回答