flatpickr 时间 选择器 使用 繁體版
原文   原文链接

1、使用方法:
1. 在页面中引入flatpicker.css和flatpicker.js文件。css

<link rel="stylesheet" type="text/css" href="/path/to/flatpickr.css">
<script src="/path/to/flatpickr.js"></script>

2. HTML代码:html

<input class='flatpickr' data-enable-time='true' data-time_24hr='true' >

代码中的 data- 属性是可选的,也能够选择写在 js 初始化参数中,去掉 data- 就能够。bootstrap

3. 初始化插件函数

 

document.getElementsByClassName("myClass").flatpickr({..config});
document.getElementById("myID").flatpickr();   // js 初始化方法
$(".calendar").flatpickr();                    // jQuery 初始化方法
// 设置参数
$(".calendar").flatpickr({

   enable-time: true,
   time_24hr: true,
   onClose: function(dateObj, dateStr, instance){

     }spa

})

4.  该插件有三个回调函数:插件

onChange function(dateObject, dateString, instance) 每第二天期被选择的时候都触发该函数。
onOpen function(dateObject, dateString, instance) 每第二天历被打开时都会触发该函数。
onClose function(dateObject, dateString, instance) 每第二天历被关闭时都会触发该函数。

 回调函数有三个参数,第一个是当前中国标准时间,格式为  Tue Feb 13 2018 00:00:00 GMT+0800 (中国标准时间),第二个是当前日期 2018-02-13,第三个则返回的是当前 flatpickr 对象:code

   

  就这样,而后咱们就能够根据须要编写相应的操做。orm

  这里举两个栗子:htm

  1. 开始时间  ——  结束时间  对最大最小时间进行限制,达到联动的效果对象

  html:

<div class="input-group">
     <input type="text" id="datetimeStart" class="form-control" placeholder="起始日期">
     <div class="input-group-addon clear-time-start">
     <
span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
   </
div> </div><div class="input-group""> <input type="text" id="datetimeEnd" class="form-control" placeholder="结束日期"> <div class="input-group-addon clear-time-end">
   <
span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
   </
div> </div>

  js:

  // 初始化 起始时间 和 结束时间
    var time_start =  $("#datetimeStart").flatpickr({
        onClose: function(dateObj, dateStr, instance){
            // doSomething
        }
    });
    var time_end = $("#datetimeEnd").flatpickr({
        onClose: function(dateObj, dateStr, instance){
            // doSomething
        }
    });
    // 时间限制
    time_start.config.onChange = function (dateObj) {
        time_end.set("minDate", dateObj.fp_incr(1));
    };
    time_end.config.onChange = function ( dateObj ) {
        time_start.set("maxDate", dateObj.fp_incr(-1));
    };

  2.  看上面的代码有人可能注意到了,这里有一个清空的操做,我一开始用 flatpickr 的 demo 方法,就没有生效,而后我就手动清空了 input 的值,结果发现单纯清空 input的值并不能触发 onChange 回调函数,结果 input 是清空了,可是选择结束时间的时候对它的最小时间仍然有限制,也就是说对 flatpickr 时间选择器 来讲 开始时间依然存在,并无获得通知说开始时间清空了。

  而后我尝试了一些办法发现 flatpickr 是有本身的清除机制的,就是 clear 方法:

     // 开始日期清空
    $('.clear-time-start').click(function () {
        time_start.clear();
    });

  这样会触发 onChange 回调,可是这个时候回调的参数 dateObj 的参数会变成 null,因此在对时间限制的地方要判断一下。

  由于我以前发现这个问题没找到答案,因此在这里记录一下,但愿能帮到你,这个方法不算好,但也算是一个思路。

     下面附一个 参数表 。

     配置参数表

    在配置参数中,全部的类型为string或boolean的参数均可以经过data-属性在HTML标签中进行设置。例如:data-min-date、data-default-date、data-default-date等。

 
参数 类型 默认值 描述
altFormat string "F j, Y" altInput的日期格式。
altInput Boolean false 是否使用某种用户友好的方式来显示日期时间。
altInputClass String "" 添加到input上的自定义class类。例如bootstrap用户可能须要添加一个form-control class。
allowInput boolean false 是否容许用户直接在输入框中输入日期。
clickOpens boolean true 是否在点击输入框时打开日期时间选择界面。若是你想经过手动.open()方法来打开,该选项设置为false。
dateFormat string "Y-m-d" 设置日期显示格式。
defaultDate String/Date Object null 设置一个初始的日期。
disable array [] 被禁用的日期。
enableTime boolean false 是否启用时间选择。
enableSeconds boolean false 在时间选择器中是否能够选择秒。
noCalendar boolean false 是否隐藏日历。
hourIncrement integer 1 小时输入框的步长。
minuteIncrement integer 5 分钟输入框的步长。
inline boolean false 是否之内联的方式显示日历。
static boolean false 日期选择器位于包裹容器的位置。
wrap boolean false 包裹元素。
maxDate String null 用户能够选择的最大日期。
minDate String null 用户能够选择的最小日期。
onChange function(dateObject, dateString) null 每第二天期被选择的时候都触发该函数。
onOpen function(dateObject, dateString) null 每第二天历被打开时都会触发该函数。
onClose function(dateObject, dateString) null 每第二天历被关闭时都会触发该函数。
parseDate function false 接收一个日期字符串并返回一个日期对象。
shorthandCurrentMonth boolean false 以简写方式显示月份
weekNumbers boolean false 是否在日历中显示星期数。
time_24hr boolean false 是否以24小时格式来显示时间。
utc boolean false 日期将会被解析、格式化和显示为UTC格式。
prevArrow string < 向前箭头图标。
nextArrow string > 向后箭头图标。
 

    日期格式字符

 
字符 描述 示例
d 月份中的天数,若是不满2个数字的会前导0。 01 - 31
D 一个星期中某一天的简写文本表示 Mon - Sun
l(小写的L) 一个星期中某一天的文本表示 Sunday - Saturday
j 不带前导0的月份中的天数 1 - 31
J 带序号后缀,不带前导0的月份中的天数 1st, 2nd, to 31st
w 使用数字来表明星期中的某一天 0 (星期天) - 6 (星期六)
F 月份的完整文本表示 January - December
m 使用数字来表示月份,前导带0。 01 - 12
n 使用数字来表示月份,前导不带0。 1 - 12
M 月份的简写文本表示 Jan - Dec
U 时间戳 1413704993
y 两个数字表明的年 99 or 03
Y 4个数字表明的年 1999 or 2003
 
字符 描述 示例
H 24小时制 00 to 23
h 12小时制 1 to 12
i 分钟 00 to 59
S 秒(不满2位数补0) 00 to 59
s 0 - 59
K AM/PM AM or PM
相关文章
相关标签/搜索
每日一句
    每一个你不满意的现在,都有一个你没有努力的曾经。
本站公众号
   欢迎关注本站公众号,获取更多信息