BootStrap daterangepicker 双日历控件
程序员文章站
2024-02-07 10:43:22
bootstrap-daterangepicker
需要bootstrap跟jquery的支持。
实例代码:
...
bootstrap-daterangepicker
需要bootstrap跟jquery的支持。
实例代码:
<!doctype html> <html> <head> <meta charset="utf-8"> <title></title> <link href="bootstrap/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet"> <link rel="stylesheet" type="text/css" media="all" href="daterangepicker/daterangepicker.css" rel="external nofollow" /> </head> <body> <form class="form-inline"> <div id="divdateid" class="pull-left daterange"> <input class="form-control" id="searchdate"></input> <i class="glyphicon glyphicon-calendar fa fa-calendar"></i> </div> </form> </body> <script type="text/javascript" src="jquery/1.12.4/jquery.min.js" ></script> <script type="text/javascript" src="bootstrap/js/bootstrap.min.js" ></script> <script type="text/javascript" src="daterangepicker/moment.min.js" ></script> <script type="text/javascript" src="daterangepicker/daterangepicker.js" ></script> <script type="text/javascript"> //默认三十天 $('#divdateid input').val(moment().subtract('days', 29).format('yyyy-mm-dd') + ' - ' + moment().format('yyyy-mm-dd')); $('#divdateid').daterangepicker({ mindate: '01/01/2015', //最小时间 maxdate : moment(), //最大时间 datelimit : { days : 365*5 }, //起止时间的最大间隔 showdropdowns : true, showweeknumbers : false, //是否显示第几周 timepicker : false, //是否显示小时和分钟 timepickerincrement : 60, //时间的增量,单位为分钟 timepicker12hour : false, //是否使用12小时制来显示时间 ranges : { //'最近1小时': [moment().subtract('hours',1), moment()], '今日': [moment().startof('day'), moment()], '昨日': [moment().subtract('days', 1).startof('day'), moment().subtract('days', 1).endof('day')], '最近7日': [moment().subtract('days', 6), moment()], '最近30日': [moment().subtract('days', 29), moment()] }, opens : 'right', //日期选择框的弹出位置 buttonclasses : [ 'btn btn-default' ], applyclass : 'btn-small btn-primary blue', cancelclass : 'btn-small', format : 'yyyy-mm-dd', //控件中from和to 显示的日期格式 separator : ' to ', locale : { applylabel : '确定', cancellabel : '取消', fromlabel : '起始时间', tolabel : '结束时间', customrangelabel : '自定义', daysofweek : [ '日', '一', '二', '三', '四', '五', '六' ], monthnames : [ '一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月' ], firstday : 1 } //汉化日期控件 }, function(start, end, label) { //格式化日期显示框 $('#searchdate').val(start.format('yyyy-mm-dd') + ' - ' + end.format('yyyy-mm-dd')); }); </script> </html>
实例图片:
参数说明:
`startdate`: (date object, moment object or string) 起始时间 `enddate`: (date object, moment object or string) 结束时间 `mindate`: (date object, moment object or string) 可选最早时间 `maxdate`: (date object, moment object or string) 可选最迟时间 `timepicker`: (boolean) 是否显示time选择 `timepickerincrement`: (number) time选择递增数 `timepicker12hour`: (boolean) 是否12小时制 `opens`: (string: 'left'/'right') 显示在元素左边还是右边 `buttonclasses`: (array) 按钮样式 `applyclass`: (string) 应用按钮样式 `cancelclass`: (string) 取消按钮样式 `format`: (string) date/time格式 `separator`: (string) 分隔符 `locale`: (object) 本地设置 `singledatepicker`: (boolean) 是否是单个时间选择器 `parentel`: (string) 将控件放到哪个元素内,默认body
其中有一个小需求调整,当我们直接使用源码选择时,为啦方便用户操作,控件在下拉选择月份时,自动帮我们刷新啦另一个控件上的日期,两个日期相差都在一个月,比如我选择1月到6月时,两个日期面板上显示不上一个1月,一个六月,如图:
如果不需要这种变化,可以修改daterangepicker.js的代码:
注释1444行跟1445行,1448跟1449行,不让它自动去改变日期面板:
在注释掉582行:
这样就能达到改变日期不改变面板的效果啦:
以上所示是小编给大家介绍的bootstrap daterangepicker 双日历控件,希望对大家有所帮助
上一篇: JS请求servlet功能示例
推荐阅读
-
BootStrap daterangepicker 双日历控件
-
BootStrap daterangepicker 双日历控件
-
Bootstrap DateTime Picker日历控件简单应用
-
bootstrap中日历范围选择插件daterangepicker的使用详解
-
bootstrap时间控件daterangepicker使用方法及各种小bug修复
-
bootstrap中日历范围选择插件daterangepicker的使用详解
-
基于bootstrap的双日历插件 daterangepicker
-
bootstrap daterangepicker双日历时间段选择控件详解
-
Bootstrap DateTime Picker日历控件简单应用
-
BootStrap的双日历时间控件使用