pe:input在p:tab内将数值重置为初始值



我的屏幕上有一个<p:tabView>,其中一个选项卡(<p:tab>)有几个<pe:inputNumber>,minValue属性设置为-9999999999.99。当我输入任何值(无论是正值还是负值)并在选项卡之间切换时,输入值将重置为其初始值,而对于未设置minValue的输入,在选项卡之间进行切换后,它将保留输入值。

是否有我缺少的属性需要设置?或者有同样的解决方法吗?

编辑:我使用的是素数面5.3和素数面扩展4.0.0。我的标签代码如下所示:

<p:tabView id="sections" style="width:inherit;background-color: #F0F0F0;">
        <p:ajax event="tabChange" listener="#{tabbedViewManagedBean.onTabChange}" />
        <p:ajax event="tabClose" listener="#{tabbedViewManagedBean.onTabClose}" />
        <p:tab title="First Tab" id="firsttab">
            <ui:include src="firsttab.xhtml" />
        </p:tab>
        <p:tab title="Second Tab" id="secondtab">
            <ui:include src="secondtab.xhtml" />
        </p:tab>
 </p:tabView>

选项卡视图托管bean在选项卡之间切换时获取该选项卡的数据。每个选项卡都有自己的会话范围的托管bean。

secondtab.xhtml的代码是:

    <ui:composition xmlns="http://www.w3.org/1999/xhtml"
        xmlns:h="http://java.sun.com/jsf/html"
        xmlns:f="http://java.sun.com/jsf/core"
        xmlns:ui="http://java.sun.com/jsf/facelets"
        xmlns:c="http://java.sun.com/jstl/core"
        xmlns:p="http://primefaces.org/ui"
        xmlns:pe="http://primefaces.org/ui/extensions">
      <h:outputText value="Net Loss :" />
        <pe:inputNumber value="#{secondTabMB.netLoss}" 
           symbol="$ " minValue="-99999999999999.99" />
    </ui:composition>

以下是我的屏幕外观

这可能会有所帮助:

<pe:inputNumber value="#{secondTabMB.netLoss}" 
       symbol="$ " minValue="-99999999999999.99">
    <p:ajax event="blur" global="false" />
</pe:inputNumber>

我试图用这段代码重新创建您的问题,但下面的代码按预期工作。我可以在不丢失值的情况下切换选项卡:

@ManagedBean
@ViewScoped
public class Test {
    private Double input1;
    private Double input2;
//Getters & Setters
}

html

<h:form>
    <p:tabView>
        <p:tab title="Input1">
            <h:outputText value="Net Loss :" />
            <div class="form-element-wrapper">
                <pe:inputNumber value="#{test.input1}" symbol="$ " >
                    <p:ajax process="@this"/>
                </pe:inputNumber>
            </div>
        </p:tab>
        <p:tab title="Input2">
            <h:outputText value="Net Loss :" />
            <div class="form-element-wrapper">
                <pe:inputNumber value="#{test.input2}" symbol="$ " minValue="-99999999999999.99" >
                    <p:ajax process="@this"/>
                </pe:inputNumber>
            </div>
        </p:tab>
    </p:tabView>
</h:form>

我添加process="@this"只是为了在失去焦点时进行ajax提交。

你能从ajax请求中提供以下代码吗?:

<p:ajax event="tabChange" listener="#{tabbedViewManagedBean.onTabChange}" />

相关内容

  • 没有找到相关文章

最新更新