我有这样的支持bean:
@ManagedBean
@SessionScoped
public class TestBean {
private String testString;
public String getTestString() {
return testString;
}
public void setTestString(String testString) {
this.testString = testString;
}
}
我的xhtml页面也非常简单:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html 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"
>
<h:head></h:head>
<h:body>
<h:form>
<h:inputText value="#{testBean.testString}"/>
<h:commandButton action="#{testController.testAction}"/>
</h:form>
</h:body>
</html>
我想要的一切 - 渲染我的h:inputText
元素没有值(空)。
我是JSF的新手,所以,你能帮助我吗?
最诚挚的问候!
UPD!
这是简化的代码,我在其他地方使用testString
而testString
有价值,我想隐藏它!我希望保持这个价值。
答案 0 :(得分:6)
如果它真的是request/view scoped bean,您可能是浏览器内置自动完成/自动填充功能的受害者。您可以通过将autocomplete="off"
添加到相关输入组件来关闭它。
<h:inputText ... autocomplete="off" />
再次注意,填充输入的不是JSF,而是webbrowser本身。清除浏览器缓存,您将看到浏览器不再执行此操作。根据浏览器品牌/版本,您还可以将其重新配置为不那么急切地自动完成。
更新:根据您的问题更新,您的bean结果是会话作用域。这不是基于请求/视图的表单的正常范围。会话范围的bean实例在同一HTTP会话中的所有浏览器窗口/选项卡(读取:所有请求/视图)之间共享。您通常只在登录会话中存储登录用户及其首选项(语言等)。当您关闭并重新启动整个浏览器或使用其他浏览器/机器时,您将只获得一个全新的实例。
将其更改为请求或查看作用域。在这个特殊的简单示例中,请求范围应该足够了:
@ManagedBean
@RequestScoped
更新2
哦,对,我最好使用@RequestScoped。但它并没有解决我的问题 - 我想保留这个值,但我不想在textInput中显示它。在请求 - 响应周期的上下文中,此值很重要。
具体的功能要求现在更加明确(在未来的问题中,请在准备问题时注意这一点,我不知道你最初是这样问的)。在这种情况下,使用具有2个属性的视图范围bean:
@ManagedBean
@ViewScoped
public class TestBean {
private String testString;
private String savedTestString;
public void testAction() {
savedTestString = testString;
testString = null;
}
// ...
}
您也可以将它存储在数据库或注入的托管bean的属性中,而后者实际上也是在会话范围内。例如。
答案 1 :(得分:2)
您应该将输入文本绑定到辅助bean中的其他字段。如果您想对testString
使用该字段,请在testString
方法中将输入的值复制到testAction
。
<h:form>
<h:inputText value="#{testBean.copyTestString}"/>
<h:commandButton action="#{testController.testAction}"/>
</h:form>
public String testAction()
{
testString = copyTestString;
return "destinationPage";
}
答案 2 :(得分:1)
某些浏览器会忽略自动填充功能 - 它可以帮助将自动填充功能放在表单标记中:
<h:form autocomplete="off">