gpt4 book ai didi

java - 如何将 JSF UIInput 组件重置为其托管 bean 值

转载 作者:行者123 更新时间:2023-12-01 15:40:10 25 4
gpt4 key购买 nike

我想在验证失败后将 JSF 输入重置为其原始托管 Bean 值。

我在同一页面中有两个表单 - 第一个表单有 commandLink初始化第二个表单。第二种表单呈现为一个对话框,其可见性通过 jQuery 切换 - 不过,出于本练习的目的,我可以仅在同一页面上使用两个表单进行说明。另外,当我在应用程序中使用 PrimeFaces 2.2.x 时,常规 h:commandLink 会出现相同的行为。以及。

我遇到的问题是:

  1. 点击第一个表单中的链接以初始化第二个表单
  2. 以第二种形式提交无效值
  3. 再次单击第一个表单中的链接以初始化第二个表单 - 无效值仍然存在和/或 UIInput 状态仍然无效。

例如 - 采用以下形式

<h:form id="pageForm">
<h:commandLink actionListener="#{testBean.initialize}">Initialize, no execute
<f:ajax render=":dialogForm"/>
</h:commandLink>
<br/>
<h:commandLink actionListener="#{testBean.initialize}">Initialize, execute=@this
<f:ajax execute="@this" render=":dialogForm"/>
</h:commandLink>

</h:form>

<h:form id="dialogForm">
<h:messages/>
String property - Valid: <h:outputText value="#{property.valid}"/>
<br/>
<h:inputText id="property" binding="#{property}" value="#{testBean.property}">
<f:validateLength minimum="3"/>
</h:inputText>
<br />
Int property - Valid: <h:outputText value="#{intValue.valid}"/>
<h:inputText id="intValue" binding="#{intValue}" value="#{testBean.intValue}">
<f:validateLongRange maximum="50" />
</h:inputText>
<br/>

<h:commandLink actionListener="#{testBean.submit}">
Submit
<f:ajax render="@form" execute="@form"/>
</h:commandLink>

<h:commandLink actionListener="#{testBean.initialize}">Initialize, execute=@this
<f:ajax execute="@this" render="@form"/>
</h:commandLink>

</h:form>

Bean 类:

@ManagedBean
@ViewScoped
public class TestBean {
private String property = "init";
private Integer intValue = 33;
// plus getters/setters

public void submit() { ... }
public void initialize() {
intValue = 33;
property = "init";
}

}

行为#1

  1. 点击页面表单上的“初始化”链接
  2. 输入被初始化为“init”、“33”
  3. 现在提交对两个字段都无效的内容,例如“aa”、“99”
  4. 现在再次单击任何“初始化”链接(它们的行为似乎都相同 - 无论形式相同还是不同,或者我是否指定了execute="@this",都没有区别。)

结果 => UIInput.isValid() = false,但两个值都会重置(“init”,“33”)。

预期=>有效= true(或者这是不合理的预期?)

行为#2

  1. 点击页面表单上的“初始化”链接
  2. 输入被初始化为“init”、“33”
  3. 现在提交对文本字段无效但对 int 字段有效的内容(“aa”、“44”)
  4. 现在再次点击任意“初始化”链接

结果=>“初始化”,有效=假; 44、有效=true

预期=>“init”,valid=true; 33、valid=true

我还看过:

JSF 2 - Bean Validation: validation failed -> empty values are replaced with last valid values from managed bean

How can I populate a text field using PrimeFaces AJAX after validation errors occur?

显式重置 UIInputs 状态的建议与 resetValue 确实有效,但我对此不满意。

现在,我有点明白为什么 isValid 没有重置 - 我对 JSF 生命周期的理解是,一旦将值提交给组件,isValid 就不会重置,直到组件成功提交并验证并且更新模型值Phase 设置 bean 值。因此,在这种情况下可能无法显式重置有效状态,因为我想使用 #{foo.valid}用于条件 CSS 样式。

但是,我不明白的是为什么成功验证的组件没有从 bean 重新初始化。也许我对 JSF 生命周期的理解有点偏差?

我了解 How can I populate a text field using PrimeFaces AJAX after validation errors occur? 的答案中列出的规则因为它们涉及单个组件而不是整个表单 - 即,如果组件成功验证但整体验证失败会发生什么?

最佳答案

事实上,可能没有比在组件上显式调用 resetValue 更好的方法了。就我而言,所有对话框都位于同一个大 JSF View 树中,并且具有打开它们的基础页面。因此,从 JSF 的角度来看,应该保留相同的 View 组件状态(包括无效输入值),直到我们离开 View 为止,因为它无法了解我们如何在客户端切换显示属性。

唯一可能起作用的事情是组成对话框的组件实际上不会在 JSF View 树中呈现,除非它们是可见的。就我而言,它们总是使用 CSS 来切换可见性来呈现。

关于java - 如何将 JSF UIInput 组件重置为其托管 bean 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8187306/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com