struts学习(二)

    struts学习进阶,第一部分讲到ActionForm和Action连用的情况,有些时候不需要使用ActionForm,这样更简洁方便。下面先来学习ForwardAction。

    在struts中有个习惯,a.jsp要跳到b.jsp最好中间经过c.do。下面就来实现这个简单的跳转。要实现这个跳转其实只需要配置struts-config.xml文件

 <action-mappings >
  	<action path="/hello" type="org.apache.struts.actions.ForwardAction" parameter=
  	"/hello.jsp"></action>
  </action-mappings>

    path是要引用的地址,如本例在hello.html中使用一个超链接

<a href="hello.do">点这里</a>

    parameter是链接到的地址。这个例子比较简单。接着学习下分发,DispatchAction。

    为什么需要DispatchAction呢,为了减少Action的数量,这种Action会根据status的具体数值选择不同的执行方法,下面看一个具体例子。

    new action,form。action继承自DispatchAction。

    在表单上要添加一个hidden域

<html:form action="demo.do" method="">
	姓名:<html:text property="name"></html:text>
	<input type="hidden" name="status" value="update"/>
	<html:submit value="提交"></html:submit>
	</html:form>

   struts-config.xml

 <action
      attribute="demoForm"
      input="/form/demo.jsp"
      name="demoForm"
      path="/demo"
      scope="request"
      type="com.tanger.struts.action.DemoAction" parameter="status">  
</action>

    注意要在其中增加一个parameter属性,属性值设置的和hidden的name一致。再看action

public ActionForward insert(ActionMapping mapping, ActionForm form,
			HttpServletRequest request, HttpServletResponse response) {
		DemoForm demoForm = (DemoForm) form;// TODO Auto-generated method stub
		System.out.println("**insert name**--->"+demoForm.getName());
		
		return null;
	}
	public ActionForward update(ActionMapping mapping, ActionForm form,
			HttpServletRequest request, HttpServletResponse response) {
		DemoForm demoForm = (DemoForm) form;// TODO Auto-generated method stub
		System.out.println("**update name**--->"+demoForm.getName());
		
		return null;
	}

   默认的方法名是execute,现在改成hidden域的值,这样可以调整hidden的value,执行的将是不同的方法。例如本例的status值为update,执行后的结果

   

扫描二维码关注公众号,回复: 603105 查看本文章
**update name**--->test

   即执行了update方法。

   现在出现一个问题,就是ActionFrom过多的问题,每一个Action都对应一个ActionForm实在是太麻烦了,所以有了DynaValidatorForm。下面我们就将上面的例子改成动态的形式。

   首先增加form-bean

<form-bean type="org.apache.struts.action.DynaActionForm" name="dynaForm">
		<form-property name="name" type="java.lang.String"/>
</form-bean>

   由于表单上只有一个属性,所以这里只写一个,如果表单有多个这里就要写多个。接着修改以前的action

   

public ActionForward update(ActionMapping mapping, ActionForm form,
			HttpServletRequest request, HttpServletResponse response) {
		//DemoForm demoForm = (DemoForm) form;// TODO Auto-generated method stub
		DynaActionForm dynaForm=(DynaActionForm)(form);
		System.out.println("**update name**--->"+dynaForm.getString("name"));
		
		return null;
	}

    改变以后获取属性的房还是不再是getName()而变成了getString(“name”)

    最后能和demoForm达到相同的效果。但是又有一个问题产生了,如果不使用ActionForm那么如何进行验证操作呢?

   struts提供了一个验证框架(validator-rules.xml),配置比较复杂,我们来做一个例子。

第一步:添加一个叫做validation.xml的验证规则(本例加入了required规则)

<?xml version="1.0"?>
<!DOCTYPE form-validation PUBLIC
          "-//Apache Software Foundation//DTD Commons Validator Rules Configuration 1.1.3//EN"
          "http://jakarta.apache.org/commons/dtds/validator_1_1_3.dtd">
<form-validation>
<formset>
<form name="validateForm">
<field depends="required" property="name">
	<arg resource="true" key="error.name"></arg>
</field>
</form>
</formset>
</form-validation>

    其中error.name是作为参数传递到errors.required={0} is required.中的{0}。

第二步:所有错误信息要在资源文件中编写(error.name,error.required)

error.name=user name
errors.required=<li>{0} is required.

第三步:配置struts-config.xml,在相应action中增加一个熟悉:validate="true"

 <action
      attribute="validateForm"
      input="/dispatch.jsp"
      name="validateForm"
      path="/validate"
      scope="request"
      type="com.tanger.struts.action.ValidateAction" validate="true" parameter="status">
</action>

第四步:由于验证框架是struts的一个组件,所以要配置此组件。添加一个插件pluge   new-->struts 1.2 pluge

<plug-in className="org.apache.struts.validator.ValidatorPlugIn">
    <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" />
  </plug-in>

 这样就完成了整体配置,在jsp页面调用validate.do即可。<html:errors/>打印错误信息。

使用了验证框架以后,可以直接通过js进行错误的提示

去掉<html:errors/> 添加<html:javascript formName="validateForm"/> 会自动生成js函数

<!-- Begin 

    var bCancel = false; 

    function validateValidateForm(form) { 
        if (bCancel) { 
            return true; 
        } else { 
            var formValidationResult; 
            formValidationResult = validateRequired(form); 
            return (formValidationResult == 1); 
        } 
    } 

    function validateForm_required () { 
     this.a0 = new Array("name", "<li>user name is required.", new Function ("varName", " return this[varName];"));
    } 

    代码非常长,只截取关键部分。

   我们在表单上调用该函数即可

<html:form action="validate.do" method="post" onsubmit="return validateValidateForm(this)">
	姓名:<html:text property="name"></html:text>
<input type="hidden" name="status" value="update"/>
<html:submit value="提交"></html:submit>
</html:form>

    这样就完成了js的调用,当name为空会弹出窗口提示。

    附件是本例子的代码

猜你喜欢

转载自ttcoool.iteye.com/blog/1926446