我不知道我做错了什么。我正在使用IceFaces,我有简单的托管bean:
public class TestingController {
private String name;
public String submit() {
setName("newName");
return null;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
并查看:
<ice:inputText value="#{testController.name}" />
<ice:commandButton value="submit" action="#{testController.submit}" />
当我在首次显示页面后提交表单时,输入将使用“newName”重新显示。当我清除输入字段并再次提交表单时,名称不会像我期望的那样用“newName”重新显示,但它仍然是空的。
这是如何引起的,我该如何解决?
答案 0 :(得分:1)
为我工作。单击“提交”后,无论先前框中的内容如何,输入框都将变为“newName”。
test.jspx
<?xml version="1.0" encoding="UTF-8"?>
<!--
Document : test
Created on : Feb 17, 2009, 2:35:12 PM
Author : drew
-->
<jsp:root xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:jsp="http://java.sun.com/JSP/Page"
xmlns:ice="http://www.icesoft.com/icefaces/component"
version="2.0">
<f:view>
<ice:form>
<ice:inputText id="inp" value="#{TestController.name}" /> <br/>
<ice:commandButton id="submit" value="SUBMIT" action="#{TestController.submit}" />
</ice:form>
</f:view>
</jsp:root>
TestController.java
public class TestController {
/** Creates a new instance of TestController */
public TestController() {
}
private String name;
public String submit() {
setName("newName");
return null;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
faces-config.xml中
<managed-bean>
<managed-bean-name>TestController</managed-bean-name>
<managed-bean-class>com.evi.web.viewdata.TestController</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
</managed-bean>
你能再向我们提供更多信息吗?
答案 1 :(得分:0)
尝试使用actionListener。因为如果您使用操作,页面会发送信息并重新加载页面,但如果您使用actionListener,则只会触发该事件。
<ice:commandButton id="submit" value="SUBMIT" actionListener="#{testController.submit}" />
在支持bean中:
public class TestingController {
private String name;
public void submit(ActionEvent event) {
setName("newName");
}