Struts的类型转换

时间:2023-03-09 14:54:38
Struts的类型转换

struts中jsp提交的数据,struts会自动转换为action中的属性类型;

对于基本的数据类型以及日期类型会自动转换;

就像前面那一篇博客的代码封装一样,会把字符串类型传过来的数据转化为相应的数据;

现在又有一种情况,日期的类型有很多种形式,我们上次输入的是这种形式:2016-12-13,会正常的显示,并且传给后台,但是日期的格式很多种,而一旦我们改成这样20161213,就会出现问题了,如下:(页面还是会相应的跳转的)

Struts的类型转换

那么,现在问题来了,就需要自定义类型格式的转换;

对于基本数据类型以及yyyy-MM-dd日期类型的日期格式会自动转换;

而其他的格式的转换,需要自定义类型转换器,有两种类型:局部类型转换器和全局类型转换器。

Struts转换器API

—TypeConverter  转换器接口

  —DefaultTypeConverter  默认类型的转换器类(实现复杂,一般不去用)

    —StrutsTypeConverter    用户编写的转换器接口,继承此类即可

转换器开发步骤

局部转换器

1、写转换器类(一般在工具包写去写)

package com.type;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map;

import org.apache.struts2.util.StrutsTypeConverter;

/**
 * 自定义类型转换器
 * @author Administrator
 *要求:格式支持yyyy-MM-dd/yyyyMMdd/yyyy年MM月dd日
 */
public class MyConverter extends StrutsTypeConverter {
	//先定义格式
	DateFormat df[]={
			new SimpleDateFormat("yyyy-MM-dd"),
			new SimpleDateFormat("yyyyMMdd"),
			new SimpleDateFormat("yyyy年MM月dd")
	};
	/**
	 * 把struts转换为指定的类型	[现在 的目标是把string转化为Date]
	 * @param arg0  当前的上下文环境
	 * @param arg1 jsp表单提交的字符串的值
	 * @param arg2 要转换的目标类型
	 */
	@Override
	public Object convertFromString(Map arg0, String[] arg1, Class arg2) {
		// TODO Auto-generated method stub
		SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
		System.out.println("hhh");
		//判断
		if (arg1 == null || arg1.length==0) {
			return null;
		}
		//判断类型必须为Date
		if (Date.class !=arg2) {
			return null;
		}
		//迭代,转换失败,就继续下一个格式的转换,转换成功直接返回
		for (int i = 0; i < df.length; i++) {
			try {
				return df[i].parse(arg1[0]);
			} catch (ParseException e) {
				continue;
			}
		}
		return null;
	}

	@Override
	public String convertToString(Map arg0, Object arg1) {
		// TODO Auto-generated method stub
		return null;
	}

}

2、配置转换器类(告诉struts应用自己的转换器,必须在类的同一个包下写)

在同包的action目录下,新建一个properties文件,

命名规则是:ActionClassName-conversion.properties;

user.birth=com.type.MyConverter

项目截图

Struts的类型转换

总结:这个局部的转换器不能给不其它action使用

这个时候要用全局的转换器

需要写一个转换器,给所有的action用!

配置全局类型转换器

  -->src/xwork-conversion.properties

  -->内容

    java.util.Data=转换器类(com.type.MyConverter)

java.util.Date=com.type.MyConverter

项目截图

Struts的类型转换


js小练习:选项卡2.0版

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>选项卡</title>
    <style type="text/css" media="screen">
    #div1 {
        width: 200px;
        position: relative;
    }

    #div1 span:first-of-type {
        position: absolute;
        left: 0;
        top: 100px;
        display: none;
    }

    #div1 span:last-of-type {
        position: absolute;
        right: 0;
        top: 100px;
        display: none;
    }

    #div1 div {
        width: 200px;
        height: 200px;
        border: 1px #000 solid;
        display: none;
    }

    #div1 input.active {
        background: red;
    }

    #div2 div {
        width: 200px;
        height: 200px;
        border: 1px #000 solid;
        display: none;
    }

    #div2 input.active {
        background: red;
    }
    </style>
</head>
<script type="text/javascript">
window.onload = function() {
	tab('div1');
    function tab(id) {
    	var oParent=document.getElementById(id);
    	var aInput = oParent.getElementsByTagName('input');;
    	var aDiv=oParent.getElementsByTagName('div');
    	var aSpan=oParent.getElementsByTagName('span');
    	var iNow=0;
    	//按钮点击
    	for (var i = aInput.length - 1; i >= 0; i--) {
    		aInput[i].index=i;
    		aInput[i].onclick=function () {
    			change(this.index);
    			iNow=this.index;
    		}
    	}

    	//鼠标靠近选择按钮出现及消失
    	oParent.onmouseover=function () {
    		for (var i = aSpan.length - 1; i >= 0; i--) {
    			aSpan[i].style.display='block';
    		}
    	}
    	oParent.onmouseout=function () {
    		for (var i = aSpan.length - 1; i >= 0; i--) {
    			aSpan[i].style.display='none';
    		}
    	}

    	//为span添加点击事件
    	aSpan[1].onclick=function () {
    		if (iNow==aDiv.length-1) {
    			iNow=0;
    		}else{
    			iNow++;
    		}
    		change(iNow);
    	}
    	aSpan[0].onclick=function () {
    		if (iNow==1) {
    			iNow=aDiv.length-1;
    		}else{
    			iNow--;
    		}
    		change(iNow);
    	}

    	//因为事件的发生而刺激切换的函数
    	function change(iNow){
    		for (var i = aInput.length - 1; i >= 0; i--) {
    			aInput[i].className='';
    			aDiv[i].style.display='none';
    		}
    		aInput[iNow].className='active';
    		aDiv[iNow].style.display = 'block';
    	}
	}
}
</script>

<body>
    <div id="div1">
        <input type="button" class="active" name="" value="1">
        <input type="button" name="" value="2">
        <input type="button" name="" value="3">
        <div style="display: block;">11111111111</div>
        <div>22222222222222 </div>
        <div>33333333333333 </div>
        <span><—</span>
        <span>—></span>
    </div>
</body>

</html>

效果如图:

Struts的类型转换