用Java的Json-lib输出的timestamp格式如下:
:{"date":6,"day":4,"hours":16,"minutes":46,"month":4,"nanos":0,"seconds":35,"time":1273135595000,"timezoneOffset":-480,"year":110}
请问如何转换成ExtJS可以显示的格式,或用ExtJS如何直接转换。
Json-lib输出的这种日期时间型Json,不像Rails一样容易转换。
这个是我的疏忽,没把这个说明白才导致你的疑惑。
这个类是一个工具类,它实现了JsonValueProcessor 接口,这个接口就在json-lib.jar包中。代码如下。
[code="java"]package com.util;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import net.sf.json.JsonConfig;
import net.sf.json.processors.JsonValueProcessor;
public class DateJsonValueProcessor implements JsonValueProcessor {
public static final String Default_DATE_PATTERN ="yyyy-MM-dd";
private DateFormat dateFormat ;
public DateJsonValueProcessor(String datePattern){
try{
dateFormat = new SimpleDateFormat(datePattern);
}catch(Exception e ){
dateFormat = new SimpleDateFormat(Default_DATE_PATTERN);
}
}
public Object processArrayValue(Object value, JsonConfig jsonConfig) {
return process(value);
}
public Object processObjectValue(String key, Object value,
JsonConfig jsonConfig) {
return process(value);
}
private Object process(Object value){
return dateFormat.format((Date)value);
}
}
[/code]
使用JsonConfig配置JsonObject对象,可以生成你想要的日期格式数据。
具体的配置使用JsonConfig对象,代码如下:
[code="java"]JsonConfig config = new JsonConfig();
config.registerJsonValueProcessor(Date.class, new DateJsonValueProcessor("yyyy-MM-dd"));
[/code]
然后使用 JSONObject类或者JSONArray的静态方法fromObject(),生成已经配置好的JSONObject或JSONArray对象。
[code="java"]JSONObject Obj = JSONObject.fromObject(bean, config);[/code]
或者
[code="java"]JSONArray arr= JSONArray.fromObject(bean, config);
[/code]
最后调用toString()方法
[code="java"]Obj.toString()[/code]
ok,现在生成就是日期格式为“yyyy-MM-dd”。。
这个日期格式可以自己修改,比如“MM-dd hh”
这个问题...
我觉得可能产生的原因是这样:
数据库里字段的类型的是日期, 你直接查了出来.
然后通过JSON转换, 就变成这样了.
你为什么不在数据库查询的时候to_char(date, 'yyyy-MM-dd hh:mm:ss')一下呢.