如何在JSF 2.0中呈现图像

时间:2011-08-17 11:56:21

标签: image jsf jsf-2

根据JSF 2.0规范,有三种方法可以使用h:graphicImage,具体取决于JSF生成HTML标记的“src”属性的方式:

<h:graphicImage value="#{resource['images:next.gif']}"/>

<h:graphicImage library="images" name="next.gif"/>

<h:graphicImage url="/resources/images/next.gif"/>

规范声明前两个应该呈现完全相同的标记。在我的JSF实现(MyFaces 2.0.2)中,这里是生成的输出HTML:

<img src="/AppName/faces/javax.faces.resource/next.gif?ln=images">

<img src="/AppName/faces/javax.faces.resource/next.gif?ln=images">

<img src="/AppName/resources/images/next.gif">

因此,如果我使用(名称,库)或(值)属性,那么图像总是会被JSF的servlet传输到客户端。如果我使用(url)属性,我可以直接链接到没有servlet干预的资源。

对我来说,第二种方法 - 将资源的直接服务器URL更快。

在什么情况下使用第一种方法 - 指定(名称,库)或(值)属性?

1 个答案:

答案 0 :(得分:8)

  

对我来说,第二种方法 - 将资源的直接服务器URL更快。

差异应该完全可以忽略不计。 “直接服务器URL到资源”方法也使用servlet(容器提供的default servlet)。请显示您的基准测试结果。


  

在什么情况下使用第一种方法 - 指定(名称,库)或(值)属性?

它允许您从JAR文件中提供资源。它还允许您以下列方式更好地动态切换库:

<h:graphicImage library="#{user.prefs.looknfeel}" name="next.gif"/>

library实际上应指向包含所有CSS / JS /图像的公共资源库,而不是特定的“图像”库。

相关问题: