Java facelets动态加载和复合组件属性

时间:2011-01-30 11:01:06

标签: jsf-2 include facelets composite-component

目前,我正在尝试使用带有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;
}

如何做到这一点?

1 个答案:

答案 0 :(得分:0)

我认为你有两个问题:

  1. 使用复合组件中的参数调用方法
  2. 为包含的页面指定一些参数
  3. 对于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