你好,欢迎来到电脑编程技巧与维护杂志社! 杂志社简介广告服务读者反馈编程社区  
合订本订阅
 
 
您的位置:技术专栏 / Web开发
Extjs4---Grid显示util.Date时间问题
 

数据库取得的date类型为java.sql.date,如果直接放入list中,然后在转json数据的时候会出现异常,


 net.sf.json.JSONException: java.lang.reflect.InvocationTargetException


一种解决办法是在放入list之前,直接转为java.util.date,但是这样在前台取不到值,因为格式不对,下面介绍我的之中方法:

java代码:


[java] 
JsonConfig cfg = new JsonConfig();   
cfg.registerJsonValueProcessor(java.util.Date.class,new DateJsonValueProcessor());   
 
 
JSONArray jsonArray = JSONArray.fromObject(users,cfg); 

DateJsonValueProcessor.java:

[java] 
package servlet; 
 
import java.sql.Timestamp; 
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() { 
        this(DEFAULT_DATE_PATTERN); 
    } 
 
    public DateJsonValueProcessor(String datePattern) { 
        try { 
            dateFormat = new SimpleDateFormat(datePattern); 
        } catch (Exception ex) { 
            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) { 
        if (value instanceof Timestamp) 
            return dateFormat.format((Timestamp) value); 
        else if (value instanceof Date) 
            return dateFormat.format((Date) value); 
        else if (value == null) 
            return ""; 
        else 
            return value.toString(); 
    } 

这样在grid中就可以取到date的值了

  推荐精品文章

·2024年12月目录 
·2024年11月目录 
·2024年10月目录 
·2024年9月目录 
·2024年8月目录 
·2024年7月目录 
·2024年6月目录 
·2024年5月目录 
·2024年4月目录 
·2024年3月目录 
·2024年2月目录 
·2024年1月目录
·2023年12月目录
·2023年11月目录

  联系方式
TEL:010-82561037
Fax: 010-82561614
QQ: 100164630
Mail:gaojian@comprg.com.cn

  友情链接
 
Copyright 2001-2010, www.comprg.com.cn, All Rights Reserved
京ICP备14022230号-1,电话/传真:010-82561037 82561614 ,Mail:gaojian@comprg.com.cn
地址:北京市海淀区远大路20号宝蓝大厦E座704,邮编:100089