EasyUI是一套比较轻巧易用的Jquery控件,在使用过程中遇到一个问题,它的列表控件——datagrid, 在显示日期列的时候,由于后台返回给页面的数据是Json格式的,其中的日期字段,在后台是正常的“2012-11-10 12:18:00”这样的格式,json序列化后返回到前台页面就被转换成一个像 /Date(1419264000000)/的格式,导致easyUI无法解析这个字段。经过一番研究,下面给出两种解决方式 希望能帮到大家!

第一种:比较简单

定义函数:
function formatterdate(val, row) {
                  var date = new Date(val);
                  return date.getFullYear() + '-' + (date.getMonth() + 1) + '-' + date.getDate();
 }
然后在datagrid中添加:
  formatter:formatterdate

函数可以根据自己的需要修改格式。

第二种解决办法:

完整Demo文件:dateboxFormat-demo

(以下所有代码都是前台页面的JS代码)

1.定义方法使日期列的显示符合阅读习惯:

  1. function formatDatebox(value) {
  2. if (value == null || value == '') {
  3. return '';
  4. }
  5. var dt = parseToDate(value);//关键代码,将那个长字符串的日期值转换成正常的JS日期格式
  6. return dt.format("yyyy-MM-dd"); //这里用到一个javascript的Date类型的拓展方法,这个是自己添加的拓展方法,在后面的步骤3定义
  7. }
  8. /*带时间*/
  9. function formatDateBoxFull(value) {
  10. if (value == null || value == '') {
  11. return '';
  12. }
  13. var dt = parseToDate(value);
  14. return dt.format("yyyy-MM-dd hh:mm:ss");
  15. }

 

2.上面用到的日期处理方法

  1. function parseToDate(value) {
  2. if (value == null || value == '') {
  3. return undefined;
  4. }
  5. var dt;
  6. if (value instanceof Date) {
  7. dt = value;
  8. }
  9. else {
  10. if (!isNaN(value)) {
  11. dt = new Date(value);
  12. }
  13. else if (value.indexOf('/Date') > -1) {
  14. value = value.replace(/\/Date(−?\d+)\//, '$1');
  15. dt = new Date();
  16. dt.setTime(value);
  17. } else if (value.indexOf('/') > -1) {
  18. dt = new Date(Date.parse(value.replace(/-/g, '/')));
  19. } else {
  20. dt = new Date(value);
  21. }
  22. }
  23. return dt;
  24. }
  25. //为Date类型拓展一个format方法,用于格式化日期
  26. Date.prototype.format = function (format) //author: meizz
  27. {
  28. var o = {
  29. "M+": this.getMonth() + 1, //month
  30. "d+": this.getDate(),    //day
  31. "h+": this.getHours(),   //hour
  32. "m+": this.getMinutes(), //minute
  33. "s+": this.getSeconds(), //second
  34. "q+": Math.floor((this.getMonth() + 3) / 3),  //quarter
  35. "S": this.getMilliseconds() //millisecond
  36. };
  37. if (/(y+)/.test(format))
  38. format = format.replace(RegExp.$1,
  39. (this.getFullYear() + "").substr(4 - RegExp.$1.length));
  40. for (var k in o)
  41. if (new RegExp("(" + k + ")").test(format))
  42. format = format.replace(RegExp.$1,
  43. RegExp.$1.length == 1 ? o[k] :
  44. ("00" + o[k]).substr(("" + o[k]).length));
  45. return format;
  46. };

 

3.步骤1定义的方法让控件在阅读状态下的显示得到纠正,但dataGrid控件还有行编辑状态,行编辑状态下还是会出现日期不能正常显示的状况,

此时需要拓展datagrid方法(这里说成重写比较贴切),使datagrid行编辑时,日期控件内的时间格式正确显示:

  1. $.extend(
  2. $.fn.datagrid.defaults.editors, {
  3. datebox: {
  4. init: function (container, options) {
  5. var input = $('<input type="text">').appendTo(container);
  6. input.datebox(options);
  7. return input;
  8. },
  9. destroy: function (target) {
  10. $(target).datebox('destroy');
  11. },
  12. getValue: function (target) {
  13. return $(target).datebox('getValue');
  14. },
  15. setValue: function (target, value) {
  16. $(target).datebox('setValue', formatDatebox(value));
  17. },
  18. resize: function (target, width) {
  19. $(target).datebox('resize', width);
  20. }
  21. },
  22. datetimebox:{
  23. init: function (container, options) {
  24. var input = $('<input type="text">').appendTo(container);
  25. input.datetimebox(options);
  26. return input;
  27. },
  28. destroy: function (target) {
  29. $(target).datetimebox('destroy');
  30. },
  31. getValue: function (target) {
  32. return $(target).datetimebox('getValue');
  33. },
  34. setValue: function (target, value) {
  35. $(target).datetimebox('setValue', formatDateBoxFull(value));
  36. },
  37. resize: function (target, width) {
  38. $(target).datetimebox('resize', width);
  39. }
  40. }
  41. });

 4.前面的准备工作做好后,接下来就是将前面写的 formatDatebox 方法应用到控件 ,datagrid控件的列属性里面有一个formatter成员,用来自定义列的显示方法。把步骤1中定义的那个 formatDatebox或formatDateboxFull方法名关联到这个成员就可以了。

(这里只截取部分代码,相信正在用这个控件的朋友一看就明白了) 

  1. $('#dg').datagrid({
  2. columns: [[
  3. { field: 'StartDate', title: '开工日期', width: 80, formatter:formatDatebox, editor: 'datebox' },
  4. { field: 'CompletedDate', title: '竣工日期', width: 80, formatter:formatDateboxFull, editor: 'datetimebox' },

你可以把前面三个步骤的代码拷贝到一个JS文件里面,在页面进行关联,然后页面应用一下其中的formatDatebox方法。

完整Demo文件:dateboxFormat-demo

easyUI的datagrid控件日期列不能正确显示Json格式数据的解决方案的更多相关文章

  1. easyUI的datagrid控件日期列格式化

    转自:https://blog.csdn.net/idoiknow/article/details/8136093 EasyUI是一套比较轻巧易用的Jquery控件,在使用过程中遇到一个问题,它的列表 ...

  2. easyui 中Datagrid 控件在列较多且无数据时,列显示不全的解决方案

    在onLoadSuccess 中加入如下代码就OK啦 $('#dg3').datagrid({ onLoadSuccess:function(data){ if(data.total==0){ var ...

  3. EasyUI 中 DataGrid 控件 列 如何绑定对象中的属性

    EasyUI 中 DataGrid 控件 是我们经常用到的控件之一, 但是 DataGrid 控件 在绑定显示列时却不支持对象属性绑定. 模型如下: public class Manager impl ...

  4. EasyUI:datagrid控件简介

    EasyUI:datagrid控件简介 1,水平滚动条属性: //显示滚动条 fitColumns:false //不显示滚动条 fitColumns:true

  5. EasyUI中datagrid控件的使用 设置多行表头(两行或多行)

    EasyUI中的datagrid控件十分强大,能生成各种复杂的报表,现在因为项目需要,需要生成一个表头两行的表,找了一些说明文档,以下用一个实例来说明一下: 第一种方法: $('#divData'). ...

  6. 关于EasyUI中DataGrid控件的一些使用方法总结

    一,DataGrid         控件的工作流程 1,通过JavaScript将一个空白的div美化成一个空白的Datagrid模板 2,Datagrid模板通过制定的Url发送请求,获取数据   ...

  7. 自定义EasyUI的datetimebox控件日期时间的显示格式(转)

    工作中遇到的问题,在此记录一下. 需求:前台页面使用了EasyUI框架,在某一个html页面中要求datetimebox显示格式为年月日和小时,如图所示: 尝试过两种方法,分别如下: 第一种方法: d ...

  8. DataGrid控件的列

    四种列(局限性较大)https://www.cnblogs.com/lonelyxmas/p/9442604.html 更强大的模板列(如控件居中等)https://www.cnblogs.com/l ...

  9. 基于MVC4+EasyUI的Web开发框架经验总结(2)- 使用EasyUI的树控件构建Web界面

    最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采用EasyUI的前端界面处理技术,走MVC的技术路线,在重 ...

随机推荐

  1. include子页面传递过来的参数传递到后台

    在页面上可以使用 ${param.moduleId}来获取 在判断中也可以使用${param.moduleId == "test" ? "1":"2& ...

  2. 怎么用C#获取Scenario step在specflow里

    公司最近在用specflow 这种BDD的模式,但PM还是想把case再存进TestManager里面一份儿一遍后期集成TestManager 自动runcase用.所以我们需要获取每个scenari ...

  3. mysql 分区表详解

    项目中要一张库表实现 list分区.并且支持多种数据库. oracle 很顺利,只是mysql 听说5.1版本就已经支持了, 可是试了很多个版本,都不行,后来查到原因是要5.5 以上版本 分区才支持 ...

  4. cocos2dx SpriteBatchNode 精灵的渲染优化类

    用处是减少对精灵的渲染次数,用法如下 SpriteFrameCache::getInstance()->addSpriteFramesWithFile("person.plist&qu ...

  5. sublime3配置及插件安装

    1.下载https://github.com/wbond/sublime_package_control中的zip文件,解压后将文件夹名更改为Package Control. 2.将1中的文件夹放入s ...

  6. 利用css进行网页布局

    网页布局: 又称版式布局,是网页UI设计师将有限的视觉元素进行有机的排列组合,将理性的思维个性的化的表现出来,是一种具有个人艺术特色的视觉传达方式.传达信息的同时有美感.网页设计特点(相对纸媒来说). ...

  7. 使用redis缓存加索引处理数据库百万级并发

    使用redis缓存加索引处理数据库百万级并发 前言:事先说明:在实际应用中这种做法设计需要各位读者自己设计,本文只提供一种思想.准备工作:安装后本地数redis服务器,使用mysql数据库,事先插入1 ...

  8. QT creator中使用opencv

    最近要用到opencv做图像方面的东西,网上很多是用VS加opencv,但自己对VS不怎么喜欢,想用QT Creator.在网上搜索了很多资料,终于花了一天的时间,在QT Creator上能使用ope ...

  9. Bash 使用技巧大补贴

    https://linuxtoy.org/archives/the-best-tips-and-tricks-for-bash.html

  10. DirectUI中模态对话框和菜单的原理(自己控制整个Windows消息循环。或者,用菜单模拟窗体打开时用SetCapture取得控制权,一旦窗体收到WM_CAPTURECHANGED消息就把窗体退出)

    经常有人问关于模态对话框和系统菜单内部实现原理方面的问题, 因为系统通过API隐藏了太多细节,这2个问题确实令初学者甚至是有经验的开发者困扰, 下面是我个人的一些经验总结. 先说模态对话框,外部看模态 ...