我正在尝试在重复的li组件中添加片段:
<ul>
<li wicket:id="listView">HERE GOES MY FRAGMENT</li>
</ul>
填充列表视图的代码如下:
@Override
protected void populateItem(final org.apache.wicket.markup.repeater.Item<Message> item) {
Message msg = item.getModelObject();
log.info("Adding message fragment to markup: " + item.getMarkupId());
item.add(new MessageFragement(item.getMarkupId(), "messageFragment", this, msg));
}
生成的预期代码为:
<ul>
<li .... wicket:id="listView></li>
<li .... wicket:id="listView></li>
....
</ul>
但是我的片段没有添加,我收到了Runtime wicket异常:
以下组件无法呈现。一个常见的问题是你 已在代码中添加了一个组件,但忘了在中引用它 标记(因此组件永远不会被渲染)。
为什么我不能将项目标记ID用作我的片段的组件ID? 我现在可以通过在li上添加额外的标签来轻松解决这个问题:
<ul><li wicket:id="listView"><div wicket:id="message"></div></li></ul>
并将标记ID“message”添加到片段中。但我不想要它。我只是想使用已经存在的&lt; li&gt;托管我的片段,它甚至可能吗?
谢谢你们
答案 0 :(得分:1)
我认为我找到了解决方案,或更好的解决方法。
我确实在&lt; li&gt;中留下了Fragment的容器标签:
<ul>
<li wicket:id="listView"><div wicket:id="message">FRAGMENT</div></li>
</ul>
之后在MessageFragment中,我只是在Fragment构造函数中设置为不使用 setRenderBodyOnly(true)函数呈现容器标记:
public MessageFragement(String id, String markupId, MarkupContainer markupProvider, final Message message) {
super(id, markupId, markupProvider, new Model<Message>(message));
setRenderBodyOnly(true);
...
}
结果如预期:
<ul>
<li wicket:id="listView" wicketpath="...listView_1">MessageFragment1</li>
<li wicket:id="listView" wicketpath="...listView_2">MessageFragment2</li>
<li wicket:id="listView" wicketpath="...listView_3">MessageFragment3</li>
</ul>
答案 1 :(得分:0)
如果你想使用你的li列表条目作为片段的占位符,你至少需要为你的片段提供一个wicket:fragment,它应该在占位符中呈现。
但是,即使你将setStripWicketTags设置为false会导致你的标记中的原始wicket:id,这个id也不会等于getMarkupId()的返回值,因为它们至少会得到一个随机后缀。还有一个组件附加到该Id,因此不可能将任何其他组件附加到它