我在我的应用中定义了这个链接:
<a href="${request.contextPath}/pages/help/applicationHelpVersion.jsf" title="#{msg['menu.version']}" onclick="window.open(this.href, 'applicationHelpVersion','left=20,top=20,width=400,height=300,toolbar=0,resizable=1'); return false;">#{msg['menu.version']}</a>
此解决方案将打开包含当前应用版本号的新浏览器窗口。
我想重新定义它,以便新对话框窗口打开。
我使用的是primefaces,我想使用模态对话框,但在所有示例中都与commandButton结合使用。
这是applicationHelpVersion.xhtml:
<ui:composition
xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:c="http://java.sun.com/jsp/jstl/core" xmlns:hr="http://java.sun.com/jsf/html"
template="/layout/helpLayout.xhtml">
<ui:define name="insert-application-content">
<div style="text-align:center">
<h1><h:outputText value="version: "/><span class="applicationVersionContent">${versionContext.productVersion}</span></h1>
<!--<h1><h:outputText value="stage: "/><span class="applicationVersionContent">${versionContext.productNameExtension}</span></h1>-->
</div>
</ui:define>
</ui:composition>
您能帮我解决一下如何使用应用版本打开新的模态对话框吗?我试过这样的事情:
<a href="${request.contextPath}/pages/help/applicationHelpVersion.jsf" title="#{msg['menu.version']}" onclick="PF('dlg1').show();">return false;">#{msg['menu.version']}</a>
<p:dialog header="Modal Dialog" widgetVar="dlg2" modal="true" height="100">
<h:outputText value="here will be version of app..."/>
</p:dialog>
我真的不知道在这里设置什么是href参数,或者是否可以这样做。在这种状态下,应用程序版本显示在新的.jsf页面中,但我需要对话框窗口。你能帮我么?谢谢。
答案 0 :(得分:0)
您不需要在链接上使用href
属性,因为您实际上并未链接到其他页面。使用链接的onclick打开对话框,使用Primefaces&#39;像这样的javascript库:
<a onclick="PF('versionDialog').show();">My link text</a>
<p:dialog widgetVar="versionDialog">
<h:outputText value="#{elToGetVersionInfo}" />
</p:dialog>
通过此示例,您的链接文本将不会像超链接一样设置样式,因为没有href
属性。如果您希望将文本设置为链接样式,请在锚标记上使用href="#"
。
您问题底部的示例已关闭,但您的onclick正在尝试使用widgetVar
dlg1
代替dlg2
,这是对话框的内容。