`
ghyghoo8
  • 浏览: 193123 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

[转]checkbox这种表单元素的处理_Struts2

阅读更多
webwork对页面诸如像checkbox这种表单元素的处理,我们如果只是简单的用来设置字段的布尔值,就像下面的处理方式,如:
  <input type="checkbox" name="user.lockedOut" value="true"/>如果用户选中这复选框,浏览器在查询串中将会送出"user.lockedOut=true",此时OGNL执行了action.getUser().setLockedOut(true)。如果用户不选中复选框,浏览器将不会送出查询串,因此,在开始,应确保已经初始化lockedOut 为false:
  private boolean m_lockedOut = false;
  public void setLockedOut(boolean lockedOut) { m_lockedOut = lockedOut; }
   但更多情况下,我们是把它当做复选(多项选择)来用,这有两种情况用checkbox来设置集合:
  一.checkbox name相同
  在一个String 类型的Set 集合里面存放许多权限,用checkbox的HTML如下:
  <input type="checkbox" name="user.priv" value="boss"/>
  <input type="checkbox" name="user.priv" value="admin"/>
  <input type="checkbox" name="user.priv" value="manager"/>
  比方说,一个用户选中前面的两项,浏览器将会送出这查询串: user.priv=boss&user.priv=admin。
  OGNL将会处理查询串:action.getUser().setPriv(String[] {"boss", "admin"})。
  Action里面的方法将会是这样:
  Set m_privileges = new HashSet();
   public void setPriv(String[] privs) {
   for (int i = 0; i < privs.length; i++) {
   m_privileges.add(privs[i]);
   }
   }
  二.checkbox name不同
  有三种处理方式:
  I.
  <input type="checkbox" name="xlist[0].id" value="444">
  <input type="checkbox" name="xlist[1].id" value="443">
  <input type="checkbox" name="xlist[2].id" value="442">
  * Action中用List集合来处理:private List xlist = new XWorkList(User.class)
   public List getXlist(){
   return xlist;
   }
  II.
  <input type="checkbox" name="xmap['0'].id" value="444">
  <input type="checkbox" name="xmap['1'].id" value="443">
  <input type="checkbox" name="xmap['2'].id" value="442">
   * Action中用Map集合来处理:private Map xmap = new XWorkMap(User.class)
   public List getXmap(){
   return xmap;
   }
  III.
  <input type="checkbox" name="xarray[0]." value="444">
  <input type="checkbox" name="xarray[1]" value="443">
  <input type="checkbox" name="xarray[2]" value="442">
   *Action中用Object[]数组来处理(注意数组的长度必须事先确定,不可以动态改动数组的大小):
   private Object[] xarray = new Object[3]
   public Object[] getXarray(){
   return xarray;
   }
   下面用一个稍为复杂一点的例子来加深对List集合处理方式的理解,其它处理方式都是异曲同工。
  multiSelect.jsp文件
  <%@page pageEncoding="gb2312" contentType="text/html;charset=gb2312"%>
  <%@taglib prefix="ww" uri="webwork" %>
  <html>
   <body>
   <form name="multi" method="post" action="multiSelect.action">
   <%int i = 0; %>
   <ww:iterator value="ulist">
   <%
   String cName = "xlist["+i+"].id";
   i++;
   %>
   <input type="checkbox" name="<%=cName%>" value="<ww:property value="id"/>">
   <ww:property value="username"/>
   <br>
   </ww:iterator>
   <input type="hidden" name="actionEvent" value="viewSelect">
   <input type="submit" value="选择">
   </form>
   </body>
  </html>
  multiSelect_result.jsp文件
  <%@page pageEncoding="gb2312" contentType="text/html;charset=gb2312"%>
  <%@taglib prefix="ww" uri="webwork" %>
  <html>
   <body>你的选择是:<br>
   <ww:iterator value="xlist">
   <ww:property value="id"/>
   <br>
   </ww:iterator>
   </body>
  </html>
  MultiSelectAction.java文件
  package com.wzj.rbac.webwork.action;
  import java.util.List;
  import com.opensymphony.xwork.Action;
  import com.opensymphony.xwork.util.XWorkList;
  import com.wzj.framework.spring.resource.BeanLocator;
  import com.wzj.rbac.ServiceFacade.UserService;
  import com.wzj.rbac.domain.object.User;
  /**
  * @desc 复选框 选择提交Action类
  * @author chikai<br>
  * @link <a href="chikaimailto:wzj616@etang.com">chikai</a>
  * @version $ MultiSelectAction.java 2004-12-5 19:11:54 $
  * @version $ Project xwork
  */
  public class MultiSelectAction implements Action {
   private final static String PRE_SUCCESS = "pre_success";
   //用户列表
   private List ulist;
   //选择的用户
   private List xlist = new XWorkList(User.class);
   private UserService uService;
   //页面执行动作判断
   private String actionEvent;
  
   public String execute() throws Exception {
   if(actionEvent!=null&&actionEvent.equals("viewSelect"))
   {
   for(int s=0;s<xlist.size();s++){
   if(((User)xlist.get(s)).getId()==null){
   xlist.remove(s);
   s--;
   }
   }
   return SUCCESS;
   }
   //获取用户业务服务
   uService = BeanLocator.getGlobalServiceLocator().getUserService();
   ulist = uService.getAllUser();
   return PRE_SUCCESS;
   }
   public List getUlist(){
   return ulist;
   }
   public List getXlist(){
   return xlist;
   }
   public void setActionEvent(String ae){
   actionEvent = ae;
   }
  }
  xwork.xml文件:
  <!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.0//EN" "http://www.opensymphony.com/xwork/xwork-1.0.dtd">
  <xwork>
  <include file="webwork-default.xml" />
   <include file="config-browser.xml" />
   <package name="pklogin" extends="webwork-default">
   <interceptors>
   <interceptor-stack name="modelParamsStack">
   <interceptor-ref name="model-driven" />
   <interceptor-ref name="params" />
   </interceptor-stack>
  </interceptors>
  <action name="multiSelect" class="com.wzj.rbac.webwork.action.MultiSelectAction">
   <result name="success" type="dispatcher">
   <param name="location">/multiSelect_result.jsp</param>
   </result>
   <result name="pre_success" type="dispatcher">
   <param name="location">/multiSelect.jsp</param>
   </result>
   <interceptor-ref name="modelParamsStack" />
  </action>
  
  </package>
  </xwork>
分享到:
评论

相关推荐

    struts2-tags-API.rar_struts2 api_struts2 tag api_struts2 tags ch

    `struts2_tag_api`则强调了标签API,这意味着文档将详细介绍如何在JSP页面中使用Struts2提供的各种标签。`struts2_tags_chm`暗示这份文档是中文版,方便国内开发者阅读和理解。 在`struts2-tags-API.chm`这个帮助...

    达内培训机密资料_struts2_day05(3)

    Struts2采用了MVC(Model-View-Controller)设计模式,将业务逻辑、数据处理与用户界面分离,从而提高了代码的可维护性和可扩展性。对于初学者而言,学习Struts2不仅可以掌握一种实用的开发技术,还能深入了解MVC...

    Struts2表单标签使用范例

    除了`&lt;s:textfield&gt;`,Struts2还提供了多种表单标签,如`&lt;s:password&gt;`用于创建密码输入框,`&lt;s:textarea&gt;`用于创建多行文本输入框,`&lt;s:radio&gt;`和`&lt;s:checkbox&gt;`用于创建单选按钮和复选框,以及`&lt;s:select&gt;`用于...

    struts2(checkbox_radio_select)表单标签的应用及详细事例

    Struts2的表单标签大大简化了JSP页面中的表单元素处理,无论是复选框、单选按钮还是下拉选择框,都能灵活地根据不同的数据结构生成相应的HTML代码。通过`list`、`listKey`和`listValue`属性,可以方便地绑定到各种...

    第3章_Struts2标签库详解与AJAX技术应用.rar

    5. `remote`标签:Struts2提供了`&lt;s:remote&gt;`标签来创建远程调用,它可以与服务器进行异步通信,并在响应后更新指定的DOM元素。 6. JSON(JavaScript Object Notation):在AJAX请求中,JSON是一种常见的数据交换...

    JSP_struts2标签大全.doc

    除此之外,Struts 2还提供了许多其他标签,如`s:textfield`用于输入文本,`s:textarea`用于多行文本输入,`s:submit`用于提交表单,`s:form`用于定义表单,`s:iterator`用于遍历集合,`s:if`和`s:else`用于条件判断...

    达内培训机密资料_struts2_day04(2)

    在Web应用开发中,经常需要处理各种表单数据以及显示数据等操作,Struts2的核心标记库正是为此而设计。例如,`&lt;s:textfield&gt;`、`&lt;s:password&gt;`等标签可以方便地创建表单元素;`&lt;s:url&gt;`、`&lt;s:a&gt;`则可以帮助开发者...

    JSP_struts2标签大全

    从简单的超链接创建到复杂的表单数据处理,再到高级的页面布局设计,Struts2标签都能轻松应对。通过上述介绍,我们已经对Struts2标签有了较为全面的认识。在实际项目开发中合理利用这些标签,不仅能显著提升开发效率...

    struts2标签介绍2

    `46_尚学堂马士兵_Struts2_Struts标签_3_bean_1.avi`可能介绍了Bean标签的基础用法,而`49_尚学堂马士兵_Struts2_Struts标签_6_fielderror.avi`则可能讲解了错误处理相关的标签。 通过学习这些内容,开发者可以更好...

    struts2对于checkboxlist的换行

    这篇博客讨论的是如何在Struts2中处理`checkboxlist`的换行问题,这在创建多列或美观的表单布局时非常有用。 `checkboxlist`在Struts2中通常与一个Action类中的属性关联,用于收集用户的多选数据。在HTML中,复选框...

    struts的htmlcheckbox标签的默认选中问题

    在Struts中,html标签库提供了丰富的HTML表单元素,包括htmlcheckbox标签,用于创建复选框。 ### Struts的htmlcheckbox标签 htmlcheckbox标签是Struts标签库中的一个成员,用于生成HTML表单中的复选框元素。它的...

    (原创)struts标签之checkboxlist选中值并换行处理

    ### Struts标签之CheckboxList选中值与换行处理详解 #### 一、引言 在Web应用开发中,表单元素的选择对于用户交互至关重要。Struts框架作为Java Web开发中的一个重要工具,提供了丰富的标签库来帮助开发者快速构建...

    Struts2_表单标签简介 示例

    Struts2框架为了简化表单的处理,提供了一系列丰富的表单标签,这些标签不仅包含了常见的HTML表单元素,还额外提供了许多高级特性。本文将详细介绍Struts2中的表单标签及其使用方法。 #### 二、Struts2表单标签概述...

    巧用struts标签之checkboxlist选中默认值换行处理

    在Struts框架中,`&lt;s:checkboxlist&gt;`是一个非常实用的标签,用于在HTML表单中创建一组复选框,通常用于用户选择多个选项。本文将深入探讨如何巧妙地处理`checkboxlist`的默认选中值以及实现换行显示。 首先,我们...

    对 Struts 2 的 s: iterator tag 中嵌套的所有 s: checkbox 进行全选、反选操作

    在这个场景中,我们关注的是`s:iterator`标签和`s:checkbox`的使用,它们是Struts 2 中视图层(JSP)的重要组件,用于迭代数据集合并呈现复选框。在Web应用中,用户经常需要进行全选和反选的操作,这通常在管理多个...

    struts2标签介绍3

    而视频资源如"50_尚学堂马士兵_Struts2_Struts标签_7_if.avi"、"51_尚学堂马士兵_Struts2_Struts标签_8_iterator.avi"和"53_尚学堂马士兵_Struts2_Struts标签_总结.avi"则是深入了解和掌握Struts2标签库的宝贵资料,...

    struts2 表单标签的使用

    在Struts2中,表单标签是用于构建用户界面的重要组件,它们帮助开发者创建交互式和动态的网页。这篇博客将深入探讨Struts2中的表单标签及其使用方法。 首先,我们需要理解Struts2表单标签的基本结构。通常,一个...

Global site tag (gtag.js) - Google Analytics