Shi*_*han 3 resources jsf localization jsf-2 outputstylesheet
我试图从书中复制一个例子,
该结构可以从下面附加的图像中可视化-
更新
将使用该库的视图与下面给出的一样简单-
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://xmlns.jcp.org/jsf/html"
xmlns:f="http://xmlns.jcp.org/jsf/core">
<h:head>
<title></title>
<h:outputStylesheet library="#{facesContext.viewRoot.locale}/default" name="css/rafa.css"/>
<h:outputScript library="#{facesContext.viewRoot.locale}/default" name="rafa.js"/>
</h:head>
<h:body>
<f:view locale="#{localeBean.mylocale}">
<div style="width:100%; text-align:center">
<h:form>
<h:commandButton value="Rafa at Roland Garros" action="#{localeBean.changeLocale('fr')}"/>
<h:commandButton value="Rafa at Wimbledon" action="#{localeBean.changeLocale('en')}"/>
<h:commandButton value="Rafa at US Open" action="#{localeBean.changeLocale('us')}"/>
<h:commandButton value="Rafa at Australian Open" action="#{localeBean.changeLocale('au')}"/>
</h:form>
</div>
<div style="width:100%; text-align:center">
<!--<h:graphicImage library="#{facesContext.viewRoot.locale}/default" name="img/rafa.png"/> -->
<h:graphicImage value="#{resource[facesContext.viewRoot.locale+='/default:img/rafa.png']}"/>
</div>
</f:view>
</h:body>
</html>
Run Code Online (Sandbox Code Playgroud)
与
@Named
@RequestScoped
public class LocaleBean {
private String mylocale = "fr";
// getters & setters
}
Run Code Online (Sandbox Code Playgroud)
我使用Glassfish 4.1.1 Application Server与Mojarra 2.2.12正在内部使用,
的rendered HTML是-
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="j_idt2">
<title></title>
<script type="text/javascript" src="/glassfish-ee/javax.faces.resource/rafa.js.xhtml?ln=fr/default&v=1_01_2">
</script><link type="text/css" rel="stylesheet" href="/glassfish-ee/javax.faces.resource/css/rafa.css.xhtml?ln=fr/default&v=1_0" />
</head>
<body>
<div style="width:100%; text-align:center">
<form id="j_idt8" name="j_idt8" method="post" action="/glassfish-ee/ch5/ch5_12/index.xhtml" enctype="application/x-www-form-urlencoded">
<input type="hidden" name="j_idt8" value="j_idt8" />
<input type="submit" name="j_idt8:j_idt9" value="Rafa at Roland Garros" />
<input type="submit" name="j_idt8:j_idt10" value="Rafa at Wimbledon" />
<input type="submit" name="j_idt8:j_idt11" value="Rafa at US Open" />
<input type="submit" name="j_idt8:j_idt12" value="Rafa at Australian Open" />
<input type="hidden" name="javax.faces.ViewState" id="j_id1:javax.faces.ViewState:0" value="---somevalue---" autocomplete="off" />
</form>
</div>
<div style="width:100%; text-align:center">
<!--<h:graphicImage library="fr/default" name="img/rafa.png"/> -->
<img src="/glassfish-ee/javax.faces.resource/img/rafa.png.xhtml?ln=fr/default&v=1_0" />
</div>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
呈现的 html 中感兴趣的相对 url-
http://localhost:8080/glassfish-ee/javax.faces.resource/rafa.js.xhtml?ln=fr/default&v=1_01_2
http://localhost:8080/glassfish-ee/javax.faces.resource/css/rafa.css.xhtml?ln=fr/default&v=1_0
http://localhost:8080/glassfish-ee/javax.faces.resource/img/rafa.png.xhtml?ln=fr/default&v=1_0
Run Code Online (Sandbox Code Playgroud)
在控制台上,我得到了这个——
2016-06-08T20:54:52.672+0530|WARNING: JSF1064: Unable to find or serve resource, rafa.js, from library, fr/default.
2016-06-08T20:54:52.673+0530|WARNING: JSF1064: Unable to find or serve resource, css/rafa.css, from library, fr/default.
2016-06-08T20:54:52.717+0530|WARNING: JSF1064: Unable to find or serve resource, img/rafa.png, from library, fr/default.
2016-06-08T20:54:57.570+0530|WARNING: JSF1064: Unable to find or serve resource, css/rafa.css, from library, fr/default.
2016-06-08T20:56:05.587+0530|WARNING: JSF1064: Unable to find or serve resource, img/rafa.png, from library, fr/default.
2016-06-08T20:56:09.542+0530|WARNING: JSF1064: Unable to find or serve resource, img/rafa.png, from library, fr/default.
Run Code Online (Sandbox Code Playgroud)
谷歌浏览器的控制台选项卡显示-
所以最后,我哪里错了?
请建议。
在接受下面建议的答案的帮助后,进行了更改,
有一个条目-
javax.faces.resource.localePrefix=fr
Run Code Online (Sandbox Code Playgroud)
使用 GET 请求访问页面时,由于1_2.js文件中的以下条目如selected上面附加的结构所示,因此会弹出警报。
alert("J'ai gagné Roland Garros ...(resources/fr/1_0/css/js/rafa.js/1_2.js)");
Run Code Online (Sandbox Code Playgroud)
即使在locale通过按所需的command button.
为什么?还需要做什么?提前致谢。
资源本地化特性在JSF 规范中的记录非常少。与您的直觉预期相反,本地化的子文件夹不会与<f:view locale>. 相反,它们将<message-bundle>与ResourceHandler.LOCALE_PREFIX使用值为的键标识的条目进行匹配javax.faces.resource.localePrefix。此外,您不应该需要明确包含#{view.locale}在library属性中。
为了让它工作,确保你已经声明了 a <message-bundle> in faces-config.xml。
<application>
<message-bundle>com.example.i18n.YourBundle</message-bundle>
</application>
Run Code Online (Sandbox Code Playgroud)
并确保它至少包含以下条目:
javax.faces.resource.localePrefix=fr
Run Code Online (Sandbox Code Playgroud)
然后,您可以按照通常的方式引用资源,而无需使用语言环境前缀和版本后缀。
<h:outputStylesheet library="default" name="css/rafa.css" />
<h:outputScript library="default" name="rafa.js" />
Run Code Online (Sandbox Code Playgroud)
我承认这可以做得更好。当<message-bundle>未指定和/或javax.faces.resource.localePrefix不存在时,它应该简单地回退到UIViewRoot#getLocale()。尽管如此,这无疑是最罕见的 JSF 特性之一。坦率地说,直到今天我才尝试过它,我认为我永远不会在现实世界的应用程序中使用它。
| 归档时间: |
|
| 查看次数: |
2782 次 |
| 最近记录: |