是否有可能重用在对话框中使用ViewScoped bean的JSF页面?



我有一个JSF页面,它与ViewScoped管理bean一起工作,该页面需要从URL传递的viewParam。

我正在使用Primefaces 4.0,我想知道是否有一种方法可以在p:对话框中使用xhtml页面,然后传递一些参数给它。

我想从哪里召唤对话框是一个不同的页面与不同的bean, ViewScoped太。

我的对话框实际上是这样的:

    <p:dialog widgetVar="w_dialogAgregarInfo">
        <h:form id="dialogAgregarInfo">
            <p:tabView id="tabView">   
                <c:forEach items="#{iniciarProcesoController.mfuncionesAsociadas}" var="mFuncion" varStatus="loop1">      
                    <p:tab id="t_funcion_#{loop1.index}" title="#{mFuncion.nombre}" titleStyle="font-size:15px;font-style: normal;font-weight: normal">
                        <f:subview id="tab_#{loop1.index}">
                            <o:massAttribute target="javax.faces.component.UIInput" name="disabled" value="#{mFuncion.soloLectura}">
                                <p:panelGrid id="pg_funcion_#{loop1.index}" style="margin: 0 auto; box-shadow: none; width: 100%">
                                    <ui:include src="#{mFuncion.paginaFuncion}"></ui:include>
                                </p:panelGrid>
                            </o:massAttribute>
                        </f:subview>
                    </p:tab>
                </c:forEach>
            </p:tabView>
        </h:form>
    </p:dialog>

我像往常一样调用这个对话框:只是告诉它显示。

<p:commandButton value="Agregar información" oncomplete="w_dialogAgregarInfo.show()"/>

但它显示空,很确定,我需要以某种方式初始化对话框的控制器,但我不知道如何实现这一点,任何帮助将不胜感激,谢谢!!

如何将参数传递给DialogFramework?

用你的参数创建一个映射:

      Map<String, List<String>> params = new HashMap<String, List<String>>();
        List<String> values = new ArrayList<String>();
        values.add("value1");
        values.add("value3");
        params.put("paramKEy", values);

则调用

  RequestContext.getCurrentInstance().openDialog("yourxhtmlpath", options, params);

这里有一个很好的例子,primefaces对话框框架

你可以使用DialogFramework

它允许你调用任何xhtml,比如:

RequestContext.getCurrentInstance().openDialog("anyPage", options, params);

如果"anyPage"匹配你的"anyPage.xhtml"页面名,选项是给对话框的一组属性。它采用如下的Map<String,Object>:

Map<String, Object> options = new HashMap<>();
options.put("modal", "true");
options.put("draggable", "false");
options.put("resizable", "false");
options.put("position", "top");
options.put("dynamic", "true");
options.put("appendTo", "@(body)");

参数是页面接收到的参数,它接受一个Map<String, List<String>> params = new HashMap<>();

List<String> values = new ArrayList<>();
values.add("exampleValue");
params.put("exampleParam", values);

您可以扩展您的bean类,使其具有与另一个bean名称相同的功能。

相关内容

  • 没有找到相关文章

最新更新