正如你所说,jsfc
当您必须将 HTML 原型“转换”为 JSF 页面时,属性本质上很有用。例如,当您有 HTML 输入文本时:
<input type="text" .../>
你可以添加jsfc
属性以便将此 HTML 组件转换为 JSF 组件:
<input type="text" jsfc="h:inputText" .../>
这相当于编写以下 JSF 代码:
<h:inputText .../>
正如 Facelets 文档中所述here https://facelets.dev.java.net/nonav/docs/dev/docbook.html#template-remove or here https://facelets.dev.java.net/nonav/docs/dev/docbook.html#template-repeat,属性jsfc
也可用于“映射”Facelets 组件。例如,您可以删除一部分 HTML 代码:
<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
组件,但我们使用 JSF 组件用 HTML 代码创建一个表ui:repeat
迭代行。
如您所见,jsfc
属性可用于将 JSF 页面中的一个 HTML 组件转换为一个 JSF 组件。因此,对于复杂的组件,例如数据表,您将不得不使用一些解决方法(使用ui:repeat
而不是h:datatable
成分)。
另一点是,您将无法使用第三方库组件,例如 RichFaces、IceFaces、Tomahawk 等提出的组件。这些库确实是 JSF 的兴趣之一。
总结一下:jsfc
可用于将 HTML 原型转换为 JSF 应用程序,主要用于创建概念验证或设计通用 UI。然而,我认为一旦“真正的”开发开始,最好避免这个组件......