我有一个页面,用户可以通过Android,iPhone,BlackBerry或未知浏览器访问该页面。我有4 rich:panel
个,每个平台一个,后者是通用平台。
代码:
<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
,我怎样才能渲染最后一个{{1}}?
答案 0 :(得分:3)
就此而言,标题中所述的问题可以具体地回答为:
<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}
地图获取请求标头的方法较短。
答案 1 :(得分:0)
您可以在托管bean方法上编写此验证,因此它将验证用户代理是否适合第4个选项。 例如:
public boolean userAgentUnknownBrowser() {
// Verify if contains the user-agent String
}
在您的网页上,您只需使用以下方法:
<rich:panel id="dlGeneric" rendered="#{myBean.userAgentUnknownBrowser()}">
答案 2 :(得分: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期间执行一次。
但是如果你在一些模型变量上测试条件,那么最好将每个面板包装成ui:fragment like
<ui:fragment rendered="#{fn:containsIgnoreCase(request.getHeader('User-Agent'), 'Android')}">
<rich:panel id="dlAndroid">
...
</rich:panel>
<ui:fragment>