一旦表格提供,另一个简单的struts动作来处理结果: package demo; /** * copyright 2004, james m. turner. * all rights reserved * * a struts action that sends the new comments to the console */ import java.io.ioexception; import javax.servlet.servletexception; import javax.servlet.http.*; import org.apache.struts.action.*; import org.apache.struts.validator.dynavalidatorform; public class processformaction extends action { public actionforward execute(actionmapping mapping, actionform form, httpservletrequest request, httpservletresponse response) throws servletexception, ioexception { dynavalidatorform df = (dynavalidatorform) form; person[] p = (person[]) df.get("people"); for (int i = 0; i < p.length; i++) { system.out.println(p[i].getfirstname() + " " + p[i]. getlastname() + ":" + p[i].getcomment()); } return mapping.findforward("success"); } } 在实际的应用中,这就是数据写回到数据库的地方。在这种情况下,他只将数据倒在控制台上所以我们可以看到他是正确收到的。假设我们为每个演员都填充了恰当的值,我们在控制台上会看到下列内容: harrison ford:indiana jones carrie fisher:postcards from the edge mark hamill:wing commander 正如我在文章开头提到的一样,还有另一个方法可以解决这个问题,而且它不需要使用会话期范围内的表格。这个方法就是使用hashmaps 来存储行。我们来看看使用hashmaps编写的同一段代码: 首先,我们添加一个新表格到struts-config.xml: 现在,我们不使用beans的排列,改为使用hashmap 来存储每个人的数据。另外,我们需要一个新的hashmap 来存储注释,原因我稍后再解释。我们也需要一个新的动作来填充数据: package demo; /** * copyright 2004, james m. turner. * all rights reserved * * a struts action that sets up a dynaform which is globally scoped */ import java.io.ioexception; import java.util.hashmap; import javax.servlet.servletexception; import javax.servlet.http.*; import org.apache.struts.action.*; import org.apache.struts.validator.dynavalidatorform; public class setuphashformaction extends action { public actionforward execute(actionmapping mapping, actionform form, httpservletrequest request, httpservletresponse response) throws servletexception, ioexception { dynavalidatorform df = (dynavalidatorform) form; hashmap hm = (hashmap) df.get("people"); person p = new person(); p = new person(); p.setdateofbirth("07/13/1942"); p.setlastname("ford"); p.setfirstname("harrison"); p.setgender("m"); hm.put("1", p); p = new person(); p.setdateofbirth("10/21/1956"); p.setlastname("fisher"); p.setfirstname("carrie"); p.setgender("f"); hm.put("2", p); p = new person(); p.setdateofbirth("09/25/1951"); p.setlastname("hamill"); p.setfirstname("mark"); p.setgender("m"); hm.put("3", p); return mapping.findforward("success"); } } 基本上,这段代码与前面的代码相同,除了我们将person 对象存储到hashmap 中,而不是排列中之外。我们也不需要创建hashmap,因为它可以作为表格初始化的一部分来动态实现。 在jsp本身中相应的技巧部分为: copyright 2004, james m turner. all rights reserved --> <%@ taglib uri="/web-inf/struts-html.tld" prefix="html" %> <%@ taglib uri="/web-inf/struts-html-el.tld" prefix="html-el" %> <%@ taglib uri="/web-inf/struts-tiles.tld" prefix="tiles" %> <%@ taglib uri="/web-inf/c.tld" prefix="c" %> <%@ taglib prefix="fmt" uri="/web-inf/fmt.tld" %> star wars actor fact page start wars actor fact page | last name | first name | date of birth | comment |
|---|
| | | |
记住:在初始化时填充的hashmap 值,只要表格显示就会消失,因为表格是请求范围的,而不是会话期范围的。特别是对于我们来说这就意味着所有的person 对象都会消失。所以,如果我们粘贴文本域到person bean 的注释属性上,在提交表格时我们将得到一个空的指针异常,因为person 对象不再位于hashmap 内(实际上,我们得到的是一个全新的空的hashmap.)。所以,我们需要将注释存储在一个单独的并行hashmap 内,它将注释当作简单的字符串来存储。 在上述的代码中还须注意几件事情。首先,因为现在正迭代hashmap条,来自c:foreach 标记的值实际上是用于堆栈条的占位符,同时具有两个属性。key 属性的值用来访问堆栈(在我们的例子中如字符"1", "2", "3"等等),value 属性的值存储在关键字之下。所以,在这种情况下,我们必须使用value 属性来得到person bean 的实属性。 而且,我们需要构造一个用于文本框的有效的struts属性域。在html-el 标记库中使用jstl 扩展就可以实现。在这种情况下,我们通过一个由演员的最后一个名字、逗号和第一个名字组成的字符串来存储注释。 最后,我们需要一个新的动作来处理结果: package demo; /** * copyright 2004, james m. turner. * all rights reserved * * a struts action that sends the new comments to the console */ import java.io.ioexception; import java.util.hashmap; import java.util.iterator; import javax.servlet.servletexception; import javax.servlet.http.*; import org.apache.struts.action.*; import org.apache.struts.validator.dynavalidatorform; public class processhashformaction extends action { public actionforward execute(actionmapping mapping, actionform form, httpservletrequest request, httpservletresponse response) throws servletexception, ioexception { dynavalidatorform df = (dynavalidatorform) form; hashmap hm = (hashmap) df.get("comments"); iterator it = hm.keyset().iterator(); while (it.hasnext()) { string key = (string) it.next(); string comment = (string) hm.get(key); system.out.println(key + ":" + comment); } return mapping.findforward("success"); } } 同样,这里最大的差别是数据都是作为hashmaps 来存储的。代码获取关键字(lastname,firstname),然后显示关键字和在控制台
|