首页 > javascript相关 > jquery教程 > 正文

详解easyui基于 layui.laydate日期扩展组件_jquery

2018-11-17 16:46:33

本人后端开发码农一个,公司前端忙的一逼,项目使用的是easyui组件,其自带的datebox组件使用起来非常不爽,主要表现在

1、自定义显示格式很麻烦

2、选择年份和月份用户体验也不好

网上有关于和 My97DatePicker 结合的例子,但感觉也用的不是很爽。

发现国内的layDate体验非常满意,所以萌生出想把这两个组件组合起来的想法,具体代码如下,本人非前端,所以只是实现了基本功能,大神勿喷哦。

easyUI版本:V1.5.2

layDate版本:V5.0

/*基于laydate日期扩展组件*/(function ($) {  function createBox(target) {    var state = $.data(target, 'laydate');    var opts = 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 (typeof options == 'string') {      var method = $.fn.laydate.methods[options];      if (method) {        return method(this, param);      } else {        return this.textbox(options, param);      }    }    options = options || {};    return this.each(function () {      var state = $.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) {      var copts = 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",//控件选择类型 year month date time datetime      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 即代表每年每月(layui 2.1.1/layDate 5.0.4 新增)      //特定的日期 {'2017-8-21': '发布')      mark: {},      onSelect: function (value, date, endDate) { },      onChange: function (value, date, endDate) { }    });})(jQuery);

使用方法一:

<input name="BYXX" type="text" id="BYXX" class="easyui-laydate" data-options="width:200,datetype:'month'" />

使用方法二:

<input type="text" id="BYXX" />  <script type="text/javascript">    $(function () {      $("#BYXX").laydate({ width: 200, datetype: 'month' });    });  </script>

别忘记引用jquery、easyui和laydate的js文件了哦

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 相关标签:jquery教程
  • 本文发布HTML5中文学习网 ,转载请注明出处,感谢您!
  • 相关文章


  • 曝网友假装外国人写投诉信 ofo秒退押金并回函致歉
  • 苹果市值缩水逾2000亿美元 遭多家投行下调目标价
  • Asp.net Core与类库读取配置文件信息的方法_实用技巧
  • asp.net在Repeater嵌套的Repeater中使用复选框详解_实用技巧
  • 利用IIS调试ASP.NET网站程序的完整步骤_实用技巧
  • Asp.Net Core轻松学习系列之配置文件_实用技巧
  • ASP.NET 页生命周期概述(小结)_实用技巧
  • 详解ASP.NET Core WebApi 返回统一格式参数_实用技巧
  • 2018年网络流行语有哪些?2018年十大网络流行语盘点
  • 华为首席财务官孟晚舟被暂扣 深圳市政府要求加方立即放人!
  • 独孤九贱(4)_PHP视频教程

    江湖传言:PHP是世界上最好的编程语言。真的是这样吗?这个梗究竟是从哪来的?学会本课程,你就会明白了。 PHP中文网出品的PHP入门系统教学视频,完全从初学者的角度出发,绝不玩虚的,一切以实用、有用...

    独孤九贱(5)_ThinkPHP5视频教程

    ThinkPHP是国内最流行的中文PHP开发框架,也是您Web项目的最佳选择。《php.cn独孤九贱(5)-ThinkPHP5视频教程》课程以ThinkPHP5最新版本为例,从最基本的框架常识开始,将...

    独孤九贱(1)_HTML5视频教程

    《php.cn原创html5视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了HTML知识。 ...

    ThinkPHP5实战之[教学管理系统]

    本套教程,以一个真实的学校教学管理系统为案例,手把手教会您如何在一张白纸上,从零开始,一步一步的用ThinkPHP5框架快速开发出一个商业项目。

    PHP入门视频教程之一周学会PHP

    所有计算机语言的学习都要从基础开始,《PHP入门视频教程之一周学会PHP》不仅是PHP的基础部分更主要的是PHP语言的核心技术,是学习PHP必须掌握的内容,任何PHP项目的实现都离不开这部分的内容,通...

    作者信息

    kevin

    永远在学习的路上!

    相关教程

  • javascript初级视频教程 javascript初级视频教程
  • jquery 基础视频教程 jquery 基础视频教程
  • javascript三级联动视频教程 javascript三级联动视频教程
  • 独孤九贱(3)_JavaScript视频教程 独孤九贱(3)_JavaScript视频教程
  • 独孤九贱(6)_jQuery视频教程 独孤九贱(6)_jQuery视频教程
  • 热门教程