问题:
i) 在 JSF2 应用程序中,我想创建一个带有选项卡控件的页面,其中,当用户单击选项卡时,下面面板的内容通过 ajax 调用从服务器中的 xhtml 文件加载。
ii)我希望它支持优雅降级(当禁用 Javascript 时),以便在单击选项卡时触发 HTTP 请求,并加载新页面......或相反,通过渐进增强。
部分解决方案:
i)我想我可以通过 BalusC 在How to ajax jsf 2 outputLink
中发布的代码示例来实现这一点:-
<h:form>
<f:ajax render=":include">
<h:commandLink value="Home" action="#{menuManager.setPage('home')}" /><br />
<h:commandLink value="FAQ" action="#{menuManager.setPage('faq')}" /><br />
<h:commandLink value="Contact" action="#{menuManager.setPage('contact')}" /><br />
</f:ajax>
</h:form>
<h:panelGroup id="include">
<ui:include src="#{menuManager.page}.xhtml" />
</h:panelGroup>
问题
我如何扩展它来解决问题(ii)或者还有其他完全不同的方法吗?我想也许我可以用 noscript 来实现这一点,但不知道怎么做!
编辑:可能的解决方案 - 尚未验证:
即使禁用了 ajax,上述代码也应该可以工作;根据http://www.laliluna.de/articles/posts/jsf-2-evaluation-test.html ,它应该只通过 HTTP 工作:)
优雅!我会尝试一下。