6

ユーザーが Android、iPhone、BlackBerry、または未知のブラウザーを介してアクセスできるページがあります。rich:panel各プラットフォームに 1 つずつ、4 つの s があり、後者は一般的なものです。

コード:

<rich:panel id="dlAndroid" rendered="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'Android')}">
    ...
</rich:panel>

<rich:panel id="dlIphone" rendered="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'iPhone')}">
    ...
</rich:panel>

<rich:panel id="dlBlackberry" rendered="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'BlackBerry')}">
    ...
</rich:panel>

<rich:panel id="dlGeneric" rendered="#{ ---> WHAT TO WRITE HERE? <--- }">

他のものがレンダリングされていない場合にのみ、最後のものをレンダリングするにはどうrich:panelすればよいですか?

4

3 に答える 3

5

要するに、タイトルに記載されている質問には、具体的に次のように答えることができます。

<rich:panel binding="#{panel1}" ...>
    ...
</rich:panel>
<rich:panel binding="#{panel2}" ...>
    ...
</rich:panel>
<rich:panel binding="#{panel3}" ...>
    ...
</rich:panel>
<rich:panel ... rendered="#{not panel1.rendered and not panel2.rendered and not panel3.rendered}">
    ...
</rich:panel>

ただし、この特定のケースでは、これらの長く曲がりくねった式を次のようにエイリアスする方がおそらく良いでしょう<c:set>:

<c:set var="android" value="#{fn:containsIgnoreCase(header['User-Agent'], 'Android')}" scope="request" />
<c:set var="iPhone" value="#{fn:containsIgnoreCase(header['User-Agent'], 'iPhone')}" scope="request" />
<c:set var="blackBerry" value="#{fn:containsIgnoreCase(header['User-Agent'], 'BlackBerry')}" scope="request" />

<rich:panel ... rendered="#{android}">
    ...
</rich:panel>
<rich:panel ... rendered="#{iPhone}">
    ...
</rich:panel>
<rich:panel ... rendered="#{blackBerry}">
    ...
</rich:panel>
<rich:panel ... rendered="#{not android and not iPhone and not blackBerry}">
    ...
</rich:panel>

#{header}暗黙的なマップによってリクエスト ヘッダーを取得するより短い方法があることに注意してください。

于 2013-02-06T01:02:46.360 に答える
0

この検証はマネージドBeanメソッドで記述できるため、ユーザーエージェントが4番目のオプションに適合するかどうかが検証されます。例:

public boolean userAgentUnknownBrowser() {
// Verify if contains the user-agent String
}

そして、あなたのページでは、次の方法を使用します。

<rich:panel id="dlGeneric" rendered="#{myBean.userAgentUnknownBrowser()}">
于 2013-02-05T19:58:20.987 に答える
0

使用できます

<c:choose>
<c:when test="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'Android')}">
<rich:panel id="dlAndroid">
...
</rich:panel>
</c:when>
<c:when test="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'iPhone')}">
<rich:panel id="dlIphone">
...
</rich:panel>
</c:when>
<c:otherwise>
<rich:panel id="dlGeneric">
    ...
</rich:panel>
</c:otherwise>
<c:choose>

同じページの POSTS 間で変更されないブラウザーの種類を決定するロジックを使用していると思うので、ここで JSTL タグを使用しても安全だと思われます。JSTL タグは、ページの CREATE VIEW 中に 1 回だけ実行されます。

ただし、モデル変数の条件をテストする場合は、各パネルを ui:fragment のようにラップすることをお勧めします

<ui:fragment rendered="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'Android')}">
    <rich:panel id="dlAndroid">
    ...
    </rich:panel>
<ui:fragment>
于 2013-02-05T20:43:11.997 に答える