详解easyui基于 layui.laydate日期扩展组件
本人后端开发码农一个,公司前端忙的一逼,项目使用的是easyui组件,其自带的datebox组件使用起来非常不爽,主要表现在
1、自定义显示格式很麻烦
2、选择年份和月份用户体验也不好
网上有关于和My97DatePicker结合的例子,但感觉也用的不是很爽。
发现国内的layDate体验非常满意,所以萌生出想把这两个组件组合起来的想法,具体代码如下,本人非前端,所以只是实现了基本功能,大神勿喷哦。
easyUI版本:V1.5.2
layDate版本:V5.0
/*
基于laydate日期扩展组件
*/
(function($){
functioncreateBox(target){
varstate=$.data(target,'laydate');
varopts=state.options;
$(target).addClass('datebox-f').textbox($.extend({},opts,{
editable:false,
icons:[{iconCls:'combo-arrow'}]
}));
$(target).next("span.textbox").addClass('datebox');
laydate.render({
elem:'#'+$(target).next("span.textbox").children(":text").attr("id"),//指定元素,
format:opts.format,
type:opts.datetype,
min:opts.min,
max:opts.max,
zIndex:opts.zIndex,
range:opts.range,
theme:opts.theme,
calendar:opts.calendar,
mark:opts.mark,
done:function(value,date,endDate){
$(target).textbox('setValue',value);
opts.onSelect.call(target,value,date,endDate);
},
change:function(value,date,endDate){
opts.onChange.call(target,value,date,endDate);
}
});
}
$.parser.plugins.push("laydate");//注册扩展组件
$.fn.laydate=function(options,param){
if(typeofoptions=='string'){
varmethod=$.fn.laydate.methods[options];
if(method){
returnmethod(this,param);
}else{
returnthis.textbox(options,param);
}
}
options=options||{};
returnthis.each(function(){
varstate=$.data(this,'laydate');
if(state){
$.extend(state.options,options);
}else{
$.data(this,'laydate',{
options:$.extend({},$.fn.laydate.defaults,$.fn.laydate.parseOptions(this),options)
});
}
createBox(this);
});
};
$.fn.laydate.methods={
options:function(jq){
varcopts=jq.textbox('options');
return$.extend($.data(jq[0],'laydate').options,{
width:copts.width,
height:copts.height,
originalValue:copts.originalValue,
disabled:copts.disabled,
readonly:copts.readonly
});
}
};
$.fn.laydate.parseOptions=function(target){
return$.extend({},$.fn.textbox.parseOptions(target));
};
$.fn.laydate.defaults=$.extend({},$.fn.textbox.defaults,
{
//laydate参数说明:http://www.layui.com/doc/modules/laydate.html#type
theme:"#0099cc",
datetype:"date",//控件选择类型yearmonthdatetimedatetime
range:false,//开启左右面板范围选择或range:'~'来自定义分割字符
//最小/大范围内的日期时间值
//如果值为字符类型,则:年月日必须用-(中划线)分割、时分秒必须用:(半角冒号)号分割。这里并非遵循format设定的格式
//如果值为整数类型,且数字<86400000,则数字代表天数,如:min:-7,即代表最小日期在7天前,正数代表若干天后
//如果值为整数类型,且数字≥86400000,则数字代表时间戳,如:max:4073558400000,即代表最大日期在:公元3000年1月1日
min:'1900-1-1',
max:'2099-12-31',
format:"yyyy-MM-dd",//自定义格式
zIndex:66666666,//层叠顺序
calendar:false,//是否显示公历节日
//标注重要日子
//每年的日期{'0-9-18':'国耻'}0即代表每一年
//每月的日期{'0-0-15':'中旬'}0-0即代表每年每月(layui2.1.1/layDate5.0.4新增)
//特定的日期{'2017-8-21':'发布')
mark:{},
onSelect:function(value,date,endDate){},
onChange:function(value,date,endDate){}
});
})(jQuery);
使用方法一:
使用方法二:
$(function(){ $("#BYXX").laydate({width:200,datetype:'month'}); });
别忘记引用jquery、easyui和laydate的js文件了哦
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。