Struts1.x中的reset()何时调用与<html:checkbox>标签的重置

原文:http://www.blogjava.net/lucky/archive/2006/04/14/41001.aspx

 

     被Struts的html:checkBox标签使用的小问题郁闷了两天,今天终于找到了解决的办法。如果大家也遇到同样的问题,可以参考。

1)需求:
        当通过菜单进入页面时,页面中的checkbox处于被选中状态,页面提交后forward回本页,对应的checkbox保持提交时的状态,也就是说:如果提交时checkbox是选中状态回来仍然是选中状态;如果用户在提交前将checkbox的勾去掉,回来时checkbox应该为为选中状态。
2)问题:
        这个需求看起来很简单,只需要
      1)在对应的form中将checkbox对应的属性设为true就行了:
                private boolean syaken = true;
      2)在对应的jsp中使用html:checkbox标签就行了
        <html:checkbox property="syaken"/>
      但问题是checkbox标签不会去set初始化值为true的checkbox属性,不赋初值时Struts默认赋为false;
      从网上找资料有人说可以实现ActionFrom的reset()方法将对应的属性值设为false,但reset方法是在form实例化以后被调用的,也就是说你初始化的值true将被重置为false,这和直接将属性值设为false没有任何区别,这样做的结果是你从菜单进入页面时checkbox是处于不被选中的状态。
    他们之间存在着矛盾,问题的关键就是每次提交时,Struts并没有去重新设置所有checkbox的属性值,而是有选择地(初始化值为false)地进行重新设置。
3)解决办法:
        超级简单,在checkbox后面添加一个和checkbox的属性同名并且value为“false”的隐藏输入框,强迫Struts去重新设置checkbox的属性值:
          <html:checkbox property="syaken"/>&nbsp;
      <input type="hidden" name="syaken" value="false">

   
这个问题郁闷了我两天,没想到解决办法这么简单。
鸣谢与扩展:
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的jsp页面代码,实现了机票选择和购买功能: ```jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>机票购买</title> </head> <body> <h1>机票选择</h1> <form action="buyTicket" method="post"> <table> <thead> <tr> <th>机票编号</th> <th>起飞时间</th> <th>到达时间</th> <th>起飞地点</th> <th>到达地点</th> <th>价格</th> <th>选择</th> </tr> </thead> <tbody> <c:forEach var="ticket" items="${ticketList}"> <tr> <td>${ticket.ticketId}</td> <td>${ticket.departureTime}</td> <td>${ticket.arrivalTime}</td> <td>${ticket.departurePlace}</td> <td>${ticket.arrivalPlace}</td> <td>${ticket.price}</td> <td><input type="checkbox" name="selectedTickets" value="${ticket.ticketId}"></td> </tr> </c:forEach> </tbody> </table> <input type="submit" value="购买"> </form> </body> </html> ``` 在上面的代码,使用了JSTL标签库的forEach标签遍历从后台传递过来的机票信息列表,然后使用HTML表格元素将机票信息以表格的形式展示出来。在每一行机票信息的最后一列,添加了一个复选框元素,name属性设置为“selectedTickets”,value属性设置为机票的唯一编号。当用户选择机票时,选复选框,表单提交时,后台程序就可以根据“selectedTickets”参数读取到用户选择的机票信息。 在表格的下方,添加了一个提交按钮,当用户选择完机票后,点击此按钮,提交表单,跳转到后台程序进行机票购买操作。 希望这段代码能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值