SimpleFormController(表单流程控制)

SimpleFormController(表单流程控制)继承自AbstractFormController类。而且提供了更简单的表单流程控制。

SimpleFormController提供了更好的两步表单支持:

  1. 准备要展示的数据,并到表单展示页面;
  2. 提交数据数据进行处理。

下面是展示的数据的处理流程图:

SimpleFormController 处理流程图

SimpleFormController提交表单流程图:

SimpleFormController 提交表单流程图

接下来咱们写一个用户注册的例子学习一下:

下面是控制器部分代码:

package com.xttblog.chapter4.web.controller;  
//省略import  
public class RegisterSimpleFormController extends SimpleFormController {      
    public RegisterSimpleFormController() {  
        setCommandClass(UserModel.class); //设置命令对象实现类  
        setCommandName("user");//设置命令对象的名字  
    }  
    //form object 表单对象,提供展示表单时的表单数据(使用commandName放入请求)  
    protected Object formBackingObject(HttpServletRequest request) throws Exception {  
        UserModel user = new UserModel();  
        user.setUsername("请输入用户名");  
        return user;  
    }  
    //提供展示表单时需要的一些其他数据    
    protected Map referenceData(HttpServletRequest request) throws Exception {  
        Map map = new HashMap();  
        map.put("cityList", Arrays.asList("山东", "北京", "上海"));  
        return map;  
    }  
    protected void doSubmitAction(Object command) throws Exception {  
        UserModel user = (UserModel) command;  
        //TODO 调用业务对象处理  
        System.out.println(user);  
    }  
}  
  • setCommandClass和setCommandName:分别设置了命令对象的实现类和名字;
  • formBackingObject和referenceData:提供了表单展示需要的视图;
  • doSubmitAction:用于执行表单提交动作,由onSubmit方法调用,如果不需要请求/响应对象或进行数据验证,可以直接使用doSubmitAction方法进行功能处理。

spring配置内容:

<bean name="/simpleForm"   
class="com.xttblog.chapter4.web.controller.RegisterSimpleFormController">  
        <property name="formView" value="register"/>  
        <property name="successView" value="redirect:/success"/>  
</bean>  
<bean name="/success" class="com.xttblog.chapter4.web.controller.SuccessController"/>
  • formView:表示展示表单时显示的页面;
  • successView:表示处理成功时显示的页面;“redirect:/success”表示成功处理后重定向到/success控制器;防止表单重复提交;“/success” bean的作用是显示成功页面,此处就不列举了。

jsp视图页面:

<!-- register.jsp 注册展示页面-->  
<form method="post">  
username:<input type="text" name="username" value="${user.username}"><br/>  
password:<input type="password" name="username"><br/>  
city:<select>  
  <c:forEach items="${cityList }" var="city">  
   <option>${city}</option>  
  </c:forEach>  
</select><br/>  
<input type="submit" value="注册"/>  
</form>  

此处可以使用${user.username}获取到formBackingObject设置的表单对象、使用${cityList}获取referenceData设置的表单支持数据;

到此一个简单的两步表单到此结束,但这个表单有重复提交表单的问题,而且表单对象到页面的绑定是通过手工绑定的,后边我们会学习spring标签库(提供自动绑定表单对象到页面)

SimpleFormController(表单流程控制)

: » SimpleFormController(表单流程控制)

原创文章,作者:kepupublish,如若转载,请注明出处:https://blog.ytso.com/251626.html

(0)
上一篇 2022年5月3日
下一篇 2022年5月3日

相关推荐

发表回复

登录后才能评论