正如您所说,jsfc
当您必须将 HTML 原型“转换”为 JSF 页面时,该属性基本上很有用。例如,当您有 HTML 输入文本时:
<input type="text" .../>
您可以添加jsfc
属性以将此 HTML 组件转换为 JSF 组件:
<input type="text" jsfc="h:inputText" .../>
这相当于编写以下 JSF 代码:
<h:inputText .../>
如此处或此处的 Facelets 文档所述,该属性还可用于“映射”Facelets 组件。例如,您可以删除部分 HTML 代码:jsfc
<span jsfc="ui:remove">
This won't be compiled either <h:outputText value="#{foo.bar}"/>
</span>
您还可以使用此属性创建表:
<table>
<tr jsfc="ui:repeat" value="#{dept.employees}" var="emp" class="#{emp.manager ? 'mngr' : 'peon'}">
<td>#{emp.lastName}</td>
<td>#{emp.firstName}</td>
</tr>
</table>
在此示例中,我们没有将此表链接到h:datatable
组件,而是使用 HTML 代码创建一个表,使用 JSF 组件ui:repeat
对行进行迭代。
如您所见,该jsfc
属性可用于将 JSF 页面中的一个 HTML 组件转换为一个 JSF 组件。因此,对于复杂的组件,例如数据表,您将不得不使用一些变通方法(使用ui:repeat
而不是h:datatable
组件)。
另一点是您将无法使用第三方库组件,例如 RichFaces、IceFaces、Tomahawk 等提出的组件。而这些库确实是 JSF 的兴趣之一。
总结一下:jsfc
将 HTML 原型转换为 JSF 应用程序很有用,主要用于创建概念证明或设计通用 UI。但是,我认为一旦“真正的”开发开始,最好避免使用这个组件......