3

現在、私は教育目的で JavaServer Faces 2.0 と Facelets ビュー テクノロジを使用して webpart テクノロジを実装しようとしています。facelet テンプレート、facelet カスタム コンポーネントを作成し、いくつかの facelet "template" クライアントを作成しました。しかし、1つのことに私は立ち往生しています。コントロールを動的に読み込んで置くことができません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ます。バッキング 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;
}

これはどのように行うことができますか?

4

1 に答える 1

0

あなたには2つの問題があると思います:

  1. 複合コンポーネントからパラメータを指定してメソッドを呼び出す
  2. インクルードされたページにパラメータを指定する

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

于 2011-05-09T10:44:59.440 に答える