目前,我正在尝试使用带有Facelets视图技术的JavaServer Faces 2.0实现webpart技术,以用于教育目的。我创建了facelet模板,facelet自定义组件,并创建了一些facelet“模板”客户端。但有一件事我被卡住了。我无法动态加载控件并将它们放入cc:attributes
。
如果我有一个页面,例如静态文本,或者将它与ManagedBean绑定,则属性ui:include
一切正常。
<ui:define name="right-column">
right-column asd
<h:link outcome="asdf" value="link_get">
<f:param name="aa" value="123" />
<f:param name="a" value="123 dd + 20" />
</h:link>
<h:commandLink action="asdf?faces-redirect=true" value="asdf">
<f:param name="aa" value="123" />
</h:commandLink><br />
<ui:include src="./resources/Controls/CategoryTree.xhtml"/><br />
This works even if I put src with MenageBean property.
<ui:include src="#{browseProducts.incudePath}"/>
</ui:define>
这是我的facelet控件(数据绑定在#{TreeBean.root}
中的此控件中:
<!-- NO INTERFACE -->
<cc:interface>
</cc:interface>
<!-- IMPLEMENTATION -->
<cc:implementation>
<!-- This is a very simply scaffolding for Category Three Control.
-->
<p:tree value="#{TreeBean.root}" var="node"
expandAnim="FADE_IN" collapseAnim="FADE_OUT">
<p:treeNode>
<h:outputText value="#{node}" />
</p:treeNode>
</p:tree>
</cc:implementation>
但是当ui:include
指向具有cc:attribute
的控件时,我遇到了问题。我不知道如何从backing bean初始化这个属性并做“东西”。
例如我有这个页面:
<ui:composition xmlns:ui="http://java.sun.com/jsf/facelets"
template="./resources/layout/Template.xhtml"
xmlns:sc="http://java.sun.com/jsf/composite/Controls">
<ui:define name="right-column">
<sc:dummy ItemCount="10" />
<ui:include src="./resources/Controls/dummy.xhtml" />
</ui:define>
</ui:composition>
这是复合控制:
<cc:interface>
<cc:attribute name="ItemCount" required="true"
shortDescription="This attribute is meaningful " />
</cc:interface>
<!-- IMPLEMENTATION -->
<cc:implementation>
<!-- How to pass ItemCount to my dummy bean to create so many items in
list as ItemCount value -->
<ui:repeat value="#{dummy.dummyList}" var="dummyItem">
<h:outputText value="#{dummyItem}" />
</ui:repeat>
</cc:implementation>
支持bean代码:
public ArrayList<String> getDummyList() {
//Here I try to get dummy list work.
dummyList = new ArrayList<String>(getDummyCount());
for (int i=0;i< getDummyCount();i++){
dummyList.add(i + "" + i);
}
return dummyList;
}
如何做到这一点?
答案 0 :(得分:0)
我认为你有两个问题:
对于1.,因为jsf 2,你可以直接调用方法,指定参数(应该是方法签名的一部分):
<ui:repeat value="#{dummy.getDummyList(cc.attrs.dummyCode)}" var="dummyItem">
<h:outputText value="#{dummyItem}" />
</ui:repeat>
但我怀疑你正在尝试使用它不适合的东西。也许你会对编写复合组件的后备java代码感兴趣,这是不同的。但是,如果你是初学者,很难掌握。我首先尝试以不同方式设计我的页面和bean交互。我不知道你要解决哪个问题,但初看起来,这个解决方案看起来太复杂了。
对于2.,你应该看看ui:param。快速谷歌搜索给了我这个:http://www.jsfcentral.com/articles/facelets_3.html