就像您说的那样,
jsfc当您必须将HTML原型“转换”为JSF页面时,该属性实际上很有用。例如,当您有HTML输入文本时:
<input type="text" .../>
您可以添加
jsfc属性以将该HTML组件转换为JSF组件:
<input type="text" jsfc="h:inputText" .../>
这等效于编写以下JSF代码:
<h:inputText .../>
如Facelets文档的此处或此处所述,该属性
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" > <td>#{emp.lastName}</td> <td>#{emp.firstName}</td> </tr></table>在此示例中,我们没有将该表链接到
h:datatable组件,而是使用JSF组件
ui:repeat在行上进行迭代,并使用HTML代码创建了一个表。
如您所见,该
jsfc属性可用于在JSF页面中将一个HTML组件转换为一个JSF组件。因此,对于复杂的组件(例如数据表),您将不得不使用一些替代方法(使用
ui:repeat代替
h:datatable组件)。
还有一点是,您将无法使用第三方库组件,例如RichFaces,IceFaces,Tomahawk等提议的组件。这些库确实是JSF的兴趣之一。
总结一下:
jsfc将HTML原型转换为JSF应用程序可能很有用,本质上用于创建概念证明或设计通用UI。但是,我认为最好在“真正的”开发开始后避免使用此组件。



