zoukankan      html  css  js  c++  java
  • jquery选择时分插件

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title></title>
            <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css">
            <link rel="stylesheet" type="text/css" href="./time/css/timePicker.css"/>
        </head>
        <body>
            <div class="row">
                    <div class="form-group">
                            <label class="col-sm-1 control-label" for="" id="">开始时间</label>
                            <div class="col-sm-5">
                                    <input type="text" class="form-control" id="beginTime"></input>
                                    <font color="red" id="validateBeginTime"></font>
                            </div>
                    </div>
            </div>
            <div class="row">
                <div class="form-group">
                    <label class="col-sm-1 control-label" for="" id="">结束时间</label>
                    <div class="col-sm-5">
                            <input type="text" class="form-control" id="endTime" ></input>
                            <font color="red" id="validateEndTime"></font>
                    </div>
                </div>
            </div>
            <script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
            <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
            <script type="text/javascript" src="./time/js/timepicker.js"></script>
            <script type="text/jscript">
                //时间选择
                $("#beginTime").hunterTimePicker();
                $("#endTime").hunterTimePicker();
            </script>
        </body>
    </html>
    
    
    //附上引入的timePicker.css文件和timepicker.js文件
    .Hunter-time-picker{
        position: absolute;
        border: 2px solid #c9cbce;
         280px;
        background: #ffffff;
        z-index: 999999;
        font-size: 0;
    }
    .Hunter-time-picker:before, .Hunter-time-picker:after{
        content: '';
        display: block;
         0;
        height: 0;
        border- 10px;
        border-style: solid;
        position: absolute;
        left: 20px;
        z-index: 999999;
    }
    .Hunter-time-picker:before{
        border-color: transparent transparent #ffffff;
        top: -17px;
        z-index: 9999999;
    }
    .Hunter-time-picker:after{
        border-color: transparent transparent #c9cbce;
        top: -20px;
    }
    .Hunter-time-picker *{
        box-sizing: border-box;
        margin: 0 auto;
        padding: 0;
        color: #666666;
        font-family: "Microsoft YaHei";
        font-size: 14px;
    }
    .Hunter-time-picker ul{
        list-style: none;
    }
    .Hunter-time-picker ul li{
        display: inline-block;
        position: relative;
        margin: 4px;
        cursor: pointer;
    }
    .Hunter-time-picker p{
        font-weight: bold;
        padding: 0 4px;
        margin-top: 4px;
        margin-bottom: 10px;
    }
    .Hunter-time-picker .line{
         340px;
        margin: 0 auto;
        margin-top: 4px;
        border-bottom: 1px solid #d8d8d8;
    }
    
    /*选择小时*/
    .Hunter-time-picker .Hunter-wrap{
        position: relative;
         100%;
        background: #ffffff;
        padding: 9px;
    }
    .Hunter-time-picker .Hunter-hour-name{
        display: inline-block;
         50px;
        height: 30px;
        text-align: center;
        line-height: 30px;
        position: relative;
        background-color: #f5f5f5;
    }
    .Hunter-time-picker .Hunter-hour-name:hover{
        color: #002DFF;
    }
    
    .Hunter-time-picker .Hunter-hour.active{
        z-index: 999999999;
    }
    .Hunter-time-picker .active .Hunter-hour-name{
        color: #ffffff;
        background-color: #3A7ADB;
    }
    .Hunter-time-picker .Hunter-minute-wrap{
        display: none;
        border: 1px solid #D8D8D8;
        background: #ffffff;
        position: absolute;
        top: 29px;
         370px;
        padding: 10px 10px 5px 10px;
    }
    .Hunter-time-picker .Hunter-minute{
         50px;
        height: 30px;
        text-align: center;
        line-height: 30px;
        color: #999999;
        background-color: #f5f5f5;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }
    .Hunter-time-picker .Hunter-minute:hover{
        color: #002DFF;
    }
    .Hunter-time-picker .Hunter-minute.active {
        color: #ffffff;
        background-color: #3A7ADB;
    }
    .Hunter-time-picker .Hunter-clean-btn{
         108px;
        height: 30px;
        background-color: #3A7ADB!important;
        color: #ffffff;
        background-image: none !important;
        border: 5px solid #3A7ADB;
        border-radius: 0;
    }
    .Hunter-time-picker .Hunter-clean-btn:hover{
        background-color: #0B4B94 !important;
        border-color: #3A7ADB;
    }
    
    
    (function ($) {
        $.hunterTimePicker = function (box, options) {
            var dates = {
                hour: ['00:00', '01:00', '02:00', '03:00', '04:00', '05:00', '06:00', '07:00', '08:00', '09:00', '10:00', '11:00', '12:00', '13:00', '14:00', '15:00', '16:00', '17:00', '18:00', '19:00', '20:00', '21:00', '22:00', '23:00'],
                minute: ['00', '05', '10', '15', '20', '25', '30', '35', '40', '45', '50', '55'],
            };
            var box = $(box);
            var template = $('<div class="Hunter-time-picker" id="Hunter_time_picker"><div class="Hunter-wrap"><ul class="Hunter-wrap" id="Hunter_time_wrap"></ul></div></div>');
            var time_wrap = $('#Hunter_time_wrap', template);
            $(document).click(function() {
                template.remove();
            });
    
            box.click(function(event){
                    event.preventDefault();
                    event.stopPropagation();
                    $('.Hunter-time-picker').remove();
                    var _this = $(this);
                    var offset = _this.offset();
                    var top = offset.top + _this.outerHeight() + 15;
                    template.css({
                        'left': offset.left,
                        'top': top,
                    });
                    buildTimePicker();
                    $('body').append(template);
    
                    $('.Hunter-time-picker').click(function(event){
                        event.preventDefault();
                        event.stopPropagation();
                    });
            });
    
            function buildTimePicker(){
                buildHourTpl();
                hourEvent();
                minuteEvent();
                cleanBtnEvent();
            };
    
            function buildHourTpl(){
                var hour_html = '<p>小时</p>';
                for(var i = 0; i < dates.hour.length; i++){
                    var temp = box.val().split(":")[0];
                    hour_html += '<li class="Hunter-hour" data-hour="' + dates.hour[i] +'"><ul class="Hunter-minute-wrap"></ul><div class="Hunter-hour-name">' + dates.hour[i] + '</div></li>';
                }
    
                hour_html += '<li class="Hunter-clean"><input type="button" class="Hunter-clean-btn" id="Hunter_clean_btn" value="清 空"></li>'
                time_wrap.html(hour_html);
            };
    
            function buildMinuteTpl(cur_time){
                var nowHour = cur_time[0].dataset.hour.split(':')[0];
                dates.minute = ['00', '05', '10', '15', '20', '25', '30', '35', '40', '45', '50', '55'];//重置分钟
                var poi = cur_time.position();
                var minute_html = '<p>分钟</p>';
                var temp = box.val().split(":")[1];
                for(var j = 0; j < dates.minute.length;j++){
                    dates.minute[j] = nowHour + ':' +dates.minute[j];
                    minute_html += '<li class="Hunter-minute" data-minute="' + dates.minute[j] + '">' + dates.minute[j] + '</li>';
                }
                time_wrap.html(minute_html);
            };
    
            function hourEvent(){
                time_wrap.on('click', '.Hunter-hour', function(event){
                    event.preventDefault();
                    event.stopPropagation();
                    var _this = $(this);
                    time_wrap.find('.Hunter-hour').removeClass('active');
                    time_wrap.find('.Hunter-hour-name').removeClass('active');
                    time_wrap.find('.Hunter-minute-wrap').hide().children().remove();
                    _this.addClass('active');
                    _this.find('.Hunter-hour').addClass('active');
                    var hourValue = _this.data('hour');
                    var temp = box.val().split(":");
                    box.val(hourValue);
                    buildMinuteTpl(_this);
                    if(options.callback) options.callback(box);
                    return false;
                });
            };
    
            function minuteEvent(){
                time_wrap.on('click', '.Hunter-minute', function(event) {
                    event.preventDefault();
                    event.stopPropagation();
                    var _this = $(this);
                    var minuteValue = _this.data('minute');
                    var temp = minuteValue;
                    box.val(temp);
                    template.remove();
                    if(options.callback) options.callback(box);
                    return false;
                });
            };
    
            function cleanBtnEvent(){
                time_wrap.on('click', '#Hunter_clean_btn', function(event){
                    event.preventDefault();
                    event.stopPropagation();
                    box.val('');
                    template.remove();
                    if(options.callback) options.callback(box);
                    return false;
                });
            };
        };
    
        $.fn.extend({
            hunterTimePicker: function (options) {
                options = $.extend({}, options);
                this.each(function () {
                    new $.hunterTimePicker(this, options);
                });
                return this;
            }
        });
    })(jQuery);

    附上效果图

     

     

  • 相关阅读:
    Intern Day5
    PTA1007
    Intern Day5
    Intern Day2
    Intern Day5
    Intern Day2
    Intern Day2
    Intern Day2
    Intern Day1
    柯南剧场版17绝海的侦探
  • 原文地址:https://www.cnblogs.com/pycmsj/p/12797188.html
Copyright © 2011-2022 走看看