这次给大家带来easyui日期时间框在ie中的兼容性如何处理,easyui日期时间框在ie中的兼容性处理的注意事项有哪些,下面就是实战案例,一起来看一下。
前几天项目进入最后准备上线阶段,测试突然发现使用easyui的datetimebox插件获取的时间在ie的时候无法获取到比当前时间还往后的时间,当时是这么写的:
$(selector).datetimebox(
	{
formatter : function(date) {
	var y = date.getfullyear();
	var m = date.getmonth() + 1;
	var d = date.getdate();
	var h = date.gethours(); //获取当前小时数(0-23)
	var mi = date.getminutes(); //获取当前分钟数(0-59)
	var s = date.getseconds(); 
	var result = y + '-' + (m < 10 ? '0' + m : m) + '-' + (d < 10 ? '0' + d : d)
+   + (h < 10 ? '0' + h : h)
+ : + (mi < 10 ? '0' + mi : mi);
	
	//console.log(result+--第127行);
	if(second==false){
	} else {
result += : + (s < 10 ? '0' + s : s);
	}
	return result;
},
  parser : function(s) {
	var t = date.parse(s);
	if (!isnan(t)) {
return new date(t);
	} else {
return new date();
	}
}
	});
测试谷歌浏览器等主流浏览器都没有问题,可以把一开始回显的时间显示出来,并可以选择时间,但是到ie的时候,却发现选择不了时间了,而且回显的日期也不对,老是当前的时间。调试了好久,才发现是ie浏览器不支持js的parse()方法。parse()方法是把日期解析转换成该日期的毫秒数。
formatter是格式化日期的格式。而parser是把解析你格式化的日期
因为parse在ie中无法使用~导致在ie下无法解析显示出格式化过后日期的时间。下面是我自己改过的代码:
$(selector).datetimebox( 
  { 
  formatter : function(date) { 
   var y = date.getfullyear(); 
 var m = date.getmonth()+1; 
 var d = date.getdate(); 
 var h = date.gethours(); 
 var min = date.getminutes(); 
 return y+'-'+(m<10?('0'+m):m)+'-'+(d<10?('0'+d):d)+' '+(h<10?('0'+h):h)+':'+min; 
  }, 
  parser : function(s) { 
 var ss = (s.split( )); 
 var ymd = ss[0].split(-); 
 var hms = ss[1].split(:); 
 //console.log(ymd+ +hms); 
 var y = parseint(ymd[0],10); 
 var m = parseint(ymd[1],10); 
 var d = parseint(ymd[2],10); 
 var h = parseint(hms[0],10); 
 var min = parseint(hms[1],10); 
 if (!isnan(y) && !isnan(m) && !isnan(d) && !isnan(h) && !isnan(min)){ 
 return new date(y,m-1,d,h,min); 
 } else { 
 return new date(); 
 } 
  } 
  });
formatter格式化的日期是xxxx-xx-xx 
xx:x。所以在下面parser解析时先通过日期和时间之间的空格,把他俩分割开来。ss[0]==xxxx-xx-xx,ss[1]==xx:xx。这样的话再通过-和:的分割,把他们分割成一个个数字,这样的话直接写入new
 date()的参数里就可以返回正确的日期格式了~~好了,经测试完美兼容ie这个坑爹的浏览器。
今天在使用时突然发现这个方法的一个bug,那就是如何一开始datetime时间框没有数据是,会报split错误,所以今天修改了下,加了个为空判断:
if(s==){ 
 return new date(); 
 }else{ 
 //alert(s); 
 var ss = (s.split( )); 
 var ymd = ss[0].split(-); 
 var hms = ss[1].split(:); 
 //console.log(ymd+ +hms); 
 var y = parseint(ymd[0],10); 
 var m = parseint(ymd[1],10); 
 var d = parseint(ymd[2],10); 
 var h = parseint(hms[0],10); 
 var min = parseint(hms[1],10); 
 if (!isnan(y) && !isnan(m) && !isnan(d) && !isnan(h) && !isnan(min)){ 
  return new date(y,m-1,d,h,min); 
 } else { 
  return new date(); 
 } 
 }
在这要注意s是个字符串类型~所以不能用s==null来做判断条件~
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
vue判断input输入内容有否有空格
vuex的mutations与actions使用详解
以上就是easyui日期时间框在ie中的兼容性如何处理的详细内容。
   
 
   