zoukankan      html  css  js  c++  java
  • 多功能日历

      平常编程的时候,偶尔有些地方会用到日历。网络上日历插件也是挺多的,但是有些功能样式可能没有,所以就需要自己去封装一下。以下日历是个人开发的,也是参照了一些资料,写的也可能存在不足,假如有项目需要用到还是可以参考一下。

      日历界面如下:

       日历css如下:

    *{padding:0;margin:0;list-style:none}
    .clearfix:after{content:"";display:block;height:0;clear:both;visibility:hidden}
    .clearfix{*zoom:1}
    .none{display:none}
    .jm-datepicker{display:block;position:absolute;z-index:9999999;background:#fff;box-shadow:0px 4px 16px 0px rgba(0,0,0,0.1);border-radius:6px;border:1px solid rgba(238,238,238,1);animation-duration:0.3s;animation-name:laydate-upbit;animation-fill-mode:both}
    .jm-datepicker .jm-panel-wrap{position:relative}
    .jm-datepicker .jm-panel{width:402px;height:426px;display:inline-block;vertical-align:top}
    .jm-datepicker .jm-control{position:absolute;top:14px;width:28px;height:28px;line-height:26px;text-align:center;border-radius:14px;font-weight:bolder;cursor:pointer;user-select:none;border:1px solid #ddd;box-sizing:border-box}
    .jm-datepicker .jm-control svg{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
    .jm-datepicker .jm-control-disabled svg{fill:#999}
    .jm-datepicker .prev-btn{left:18px}
    .jm-datepicker .next-btn{right:18px}
    .jm-datepicker .jm-panel-head{width:100%;height:56px;line-height:56px;text-align:center;font-weight:bold;color:#333;font-size:16px}
    .jm-datepicker .jm-panel-weekbar{width:100%}
    .jm-datepicker .jm-panel-weekbar span{width:50px;height:30px;line-height:30px;font-size:12px;color:#999;display:inline-block;text-align:center}
    .jm-datepicker .jm-panel-body{padding:0 18px 0 20px;box-sizing:border-box}
    .jm-datepicker .jm-date-box{width:50px;height:50px;display:inline-block;float:left;cursor:default;position:relative;margin-bottom:2px}
    .jm-datepicker .jm-date-box .sel-label,.jm-datepicker .jm-date-box .fes-txt{position:absolute;top:10px;width:100%;color:#fff;font-size:12px;text-align:center}
    .jm-datepicker .jm-date-box .fes-txt{color:#333}
    .jm-datepicker .jm-date-box .date-num{width:100%;height:50px;padding-top:24px;box-sizing:border-box;text-align:center;font-weight:bold;color:#333;font-size:16px}
    .jm-datepicker .jm-date-box:nth-child(7n-6) .date-num,.jm-datepicker .jm-date-box:nth-child(7n) .date-num{color:#E62129}
    .jm-datepicker .date-sel-start,.jm-datepicker .date-sel-end,.jm-datepicker .date-selected{background:#EB4D54!important;color:#fff;border-radius:4px}
    .jm-datepicker .date-sel-start p,.jm-datepicker .date-sel-end p,.jm-datepicker .date-selected p{color:#fff!important}
    .jm-datepicker .date-sel-passed{background:#FEF2F2 !important}
    .jm-datepicker .date-past{opacity:.5}
    .jm-datepicker .jm-date-box:nth-child(7n-6).date-past .date-num,.jm-datepicker .jm-date-box:nth-child(7n).date-past .date-num{color:#333}
    .jm-datepicker-hide{display:none}
    @keyframes laydate-upbit{from{transform:translate3d(0,20px,0);opacity:.3}
    to{transform:translate3d(0,0,0);opacity:1}
    }@-webkit-keyframes laydate-upbit{from{transform:translate3d(0,20px,0);opacity:.3}
    to{transform:translate3d(0,0,0);opacity:1}
    }
    View Code

      html部分:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <link rel="stylesheet" href="css/datepicker.css">
    </head>
    <style>
    .date-box{
        width: 300px;
        height: 30px;
        margin: 100px;
    }
    .date-box input{
        width: 100px;
        height: 30px;
        padding: 0 0 0 10px;
    }
    .date-box span{
        padding: 0 0 0 10px;
    }
    </style>
    <body>
        <svg aria-hidden="true" style="position: absolute;  0px; height: 0px; overflow: hidden;">
            <symbol viewBox="0 0 20 20" id="icon-back">
                <path d="M10.99,15.4870409 C10.71,15.7896159 10.33,16.0705783 9.97,15.9841283 C9.61,16.0489658 9.27,15.7463909 8.99,15.4870409 L0.33,6.08560574 C-0.11,5.61013086 -0.11,4.83208105 0.33,4.35660616 C0.77,3.88113128 1.49,3.88113128 1.93,4.35660616 L9.99,13.304179 L18.07,4.35660616 C18.51,3.88113128 19.23,3.88113128 19.67,4.35660616 C20.11,4.83208105 20.11,5.61013086 19.67,6.08560574 L10.99,15.4870409 Z" id="路径"
                transform="translate(10.000000, 10.000000) rotate(-270.000000) translate(-10.000000, -10.000000) "></path>
            </symbol>
            <symbol viewBox="0 0 20 20" id="icon-right">
                 <path d="M10.99,15.4870409 C10.71,15.7896159 10.33,16.0705783 9.97,15.9841283 C9.61,16.0489658 9.27,15.7463909 8.99,15.4870409 L0.33,6.08560574 C-0.11,5.61013086 -0.11,4.83208105 0.33,4.35660616 C0.77,3.88113128 1.49,3.88113128 1.93,4.35660616 L9.99,13.304179 L18.07,4.35660616 C18.51,3.88113128 19.23,3.88113128 19.67,4.35660616 C20.11,4.83208105 20.11,5.61013086 19.67,6.08560574 L10.99,15.4870409 Z" id="路径"  transform="translate(10.000000, 10.000000) rotate(-90.000000) translate(-10.000000, -10.000000) "></path>
            </symbol>
        </svg>
    
        <div class="date-box"><span>点击显示日历:</span><input type="text" id="stDate"><span id="week"></span></div>
    
        <script src="js/datepicker.js"></script>
        <script>
            window.addEventListener('load',function(){
                var inpObj = document.getElementById('stDate');
                var weekObj = document.getElementById('week');
                inpObj.addEventListener('click',function(){
                    if(datePicker){
                        datePicker.show();
                    }else{
                        var datePicker = new DatePicker({
                            mode:'single',
                            month: 2,
                            attachTo: document.body,
                            selLabels:['去程'],
                            selDates:[],
                            isShow: true,
                            selectionType: 'callback',
                            onSelection: function(dateGroup){
                                inpObj.value = getSimpleDate(dateGroup[0]);
                                weekObj.innerHTML =getWeekByDate(dateGroup[0]);
                                datePicker.hide();
                            }
                        });
                        datePicker.init();
                        datePicker.rootTmp.style.left = inpObj.offsetLeft+'px';
                        datePicker.rootTmp.style.top = inpObj.offsetTop+inpObj.offsetHeight+'px';
                    }
                })
            })
    
        //获取月份日期
        function getSimpleDate(dateStr){
            var strArr = dateStr.split('/');
            if(strArr[1]<10){
                strArr[1] = 0+strArr[1];
            }
            if(strArr[2]<10){
                strArr[2] = 0+strArr[2];
            }
            return strArr[0]+'-'+strArr[1]+'-'+strArr[2];
        }
    
        //获取星期
        function getWeekByDate(date) {
            var weekArray = new Array("周日", "周一", "周二", "周三", "周四", "周五", "周六");
            var week = weekArray[new Date(date).getDay()];
            return week;
        }
            
        </script>
    </body>
    </html>
    View Code

      日历js部分:

    // +--------------------------------------------------------------------------------------
    // | datepicker.js
    // +--------------------------------------------------------------------------------------
    // | time:2020-08-25
    // +--------------------------------------------------------------------------------------
    // | Author: lcy
    // +--------------------------------------------------------------------------------------
    // | 使用:
    // |      引入js文件,调用方法如下:
    // |      var datePicker = new DatePicker({
    // |          mode:'single',                    //传入日历选择类型['single':单选]、['range':多选]
    // |          month: 2,                        //传入日历创建月份个数
    // |          attachTo: document.body,        //添加到的目标容器
    // |          selLabels:['出发'],                //选中显示的文字数组[单选只传1个,多选传2个]
    // |          selDates:[],                    //选中的日期数组
    // |        isShow: false,                    //是否显示
    // |          selectionType: 'callback',        //回调类型
    // |        onSelection: function(res){}    //参数为选中日期数组,有传回调类型时调用,没则关闭弹窗
    // |      });
    // |      
    // +---------------------------------------------------------------------------------------
    
    var DatePicker = (function(){
        function datePicker(option){
            this.mode = option.mode || 'single';     //单选日历'single',选区日历'range'
            this.month = option.month || 1;         //单个月参数1,双月份参数2
            this.attachTo = option.attachTo || '';     //容器
            this.selLabels = option.selLabels || [];//选中设置文字标签
            this.selDates = option.selDates || [];     //选中的日期
            this.isShow = option.isShow || false;
            this.selectionType = option.selectionType || 'callback'; //回调类型
            this.onSelection = option.onSelection || null; //选中后回调函数
            this.curYear = new Date().getFullYear();//
            this.curMonth = new Date().getMonth()+1;//
            this.curDate = new Date().getDate();    //
            this.selArea =[];                         //选区范围
        }
        datePicker.prototype ={
            init: function(){
                this.create();
            },
            create: function(){
                //根容器
                var rootTmp = document.createElement('div');
                rootTmp.classList.add('jm-datepicker');
                if(this.mode == 'range'){
                    rootTmp.classList.add('jm-datepicker-range');
                }else{
                    rootTmp.classList.add('jm-datepicker-single');
                }
                if(!this.isShow){
                    rootTmp.classList.add('jm-datepicker-hide');
                }
                this.rootTmp = rootTmp;
    
                var panelWrap = document.createElement('div');
                panelWrap.classList.add('jm-panel-wrap');
    
                //创建多少个月份
                if(this.month !=''){
                    for(var i=0; i<this.month; i++){
                        panelWrap.appendChild(this.createPanel());
                    }
                }
                this.panelEls = panelWrap;
    
                // 根容器添加左右控制箭头及月份版块
                rootTmp.appendChild(panelWrap);
                rootTmp.appendChild(this.createLeftCtrl());
                rootTmp.appendChild(this.createRightCtrl());
    
                //添加到容器中
                if(this.attachTo !=''){
                    var datePicker;
                    if(this.mode == 'range'){
                        datePicker = document.querySelector('.jm-datepicker-range');
                    }else{
                        datePicker = document.querySelector('.jm-datepicker-single');
                    }
                    if(datePicker == null){
                        this.attachTo.appendChild(rootTmp);
                    }else{
                        if(datePicker.className.indexOf('jm-datepicker-hide')!=-1){
                            datePicker.classList.remove('jm-datepicker-hide');
                        }
                    }
                }
                this.refresh(this.curMonth);
                this.bindEvent();
            },
            //创建月份
            createPanel:function(){
                var panel = document.createElement('div');
                panel.classList.add('jm-panel');
                panel.appendChild(this.createMonthHead());
                panel.appendChild(this.createMonthBody());
                return panel;
            },
            //创建左箭头
            createLeftCtrl: function(){
                var leftCtrl = document.createElement('a');
                leftCtrl.classList.add('jm-control');
                leftCtrl.classList.add('prev-btn');
                leftCtrl.classList.add('jm-control-disabled');
                var svg = '<svg class="icon" aria-hidden="true" width="12px" height="12px">';
                    svg+= '<use xlink:href="#icon-back" x="0" y="0" width="12px" height="12px"></use>';
                    svg+= '</svg>';
                leftCtrl.innerHTML = svg;
                this.prevBtn = leftCtrl;
                return leftCtrl;
            },
            //创建右箭头
            createRightCtrl: function(){
                var rightCtrl = document.createElement('a');
                rightCtrl.classList.add('jm-control');
                rightCtrl.classList.add('next-btn');
                var svg = '<svg class="icon" aria-hidden="true" width="12px" height="12px">';
                    svg+= '<use xlink:href="#icon-right" x="0" y="0" width="12px" height="12px"></use>';
                    svg+= '</svg>';
                rightCtrl.innerHTML = svg;
                this.nextBtn = rightCtrl;
                return rightCtrl;
            },
            //创建月份头部
            createMonthHead: function(){
                var panelHead = document.createElement('div');
                panelHead.classList.add('jm-panel-head');
                var headTmp= '<h3>';
                    headTmp+= '<span class="yy-txt"></span>年';
                    headTmp+= '<span class="mm-txt"></span>月';
                    headTmp+= '</h3>';
                panelHead.innerHTML = headTmp;
                return panelHead;
            },
            //创建月份头部星期
            createWeekBar: function(){
                var weekStr = ['日','一','二','三','四','五','六'];
                var weekBar = document.createElement('div');
                weekBar.classList.add('jm-panel-weekbar');
                var tmp ='';
                for(var i=0; i<weekStr.length; i++){
                    tmp +='<span>'+weekStr[i]+'</span>';
                }
                weekBar.innerHTML=tmp;
                return weekBar;
            },
            //创建日期格子
            createDateGrid: function(){
                var datesWrap = document.createElement('div');
                datesWrap.classList.add('jm-panel-dates');
                datesWrap.classList.add('clearfix');
    
                var cols = 7;//7列
                var rows = 6;//6行
                for(var i=0; i<rows; i++){
                    for(var j=0; j<cols; j++){
                        var dateBox = document.createElement('div');
                        dateBox.classList.add('jm-date-box');
                        datesWrap.appendChild(dateBox);
                    }
                }
                return datesWrap;
            },
            //创建月份内容(头部星期+日期内容)
            createMonthBody: function(){
                var con = document.createElement('div');
                con.classList.add('jm-panel-body');
                con.appendChild(this.createWeekBar());
                con.appendChild(this.createDateGrid());
                return con;
            },
            refresh: function(){
    
                var _this = this;
                var month = this.curMonth;
                var yy,mm;
        
                if(month>12){
                    if(month%12 == 0){
                        yy = _this.curYear+parseInt(month/12)-1;
                        mm = 12;
                    }else{
                        yy = this.curYear+parseInt(month/12);
                        mm = month%12;
                    }
                }else{
                    yy = this.curYear;
                    mm = month;
                }
    
                var dateList = []; //月份天数
                if(this.isLeapYear(yy)){
                    dateList =[31,29,31,30,31,30,31,31,30,31,30,31];
                }else{
                    dateList =[31,28,31,30,31,30,31,31,30,31,30,31];
                }
    
                // 查找日期格子
                if(this.month == 1){ //单日历情况
                    var week = new Date(yy+'/'+mm+'/'+'1').getDay();//当前月1号星期几
                    var curDates = dateList[mm-1]; //当前月份天数
    
                    // 设置头部年月
                    this.panelEls.querySelector('.yy-txt').innerHTML=yy;
                    this.panelEls.querySelector('.mm-txt').innerHTML=mm;
    
                    //查找所有日期格子
                    var dateGroup =this.panelEls.querySelectorAll('.jm-date-box');
                    if(dateGroup.length>0){
                        for(var x=0; x<dateGroup.length; x++){
                            if(x<week){
                                dateGroup[x].innerHTML ='';
                                dateGroup[x].classList.add('date-disabled');
                            }else{
                                if(x-week+1<curDates || x-week+1 == curDates){
                                    var childTmp = '<p class="sel-label"></p>';
                                    childTmp+= '<p class="fes-txt">'+_this.setFestText(mm,parseInt(x-week+1))+'</p>';
                                    childTmp+= '<p class="date-num">'+parseInt(x-week+1)+'</p>';
                                    dateGroup[x].innerHTML = childTmp;
                                    dateGroup[x].setAttribute('data-date',yy+'/'+mm+'/'+parseInt(x-week+1));
    
                                    //如果存在空格子样式去掉
                                    if(dateGroup[x].className.indexOf('date-disabled')!=-1){
                                        dateGroup[x].classList.remove('date-disabled');
                                    }
                                    //如果存在选中日期样式去掉
                                    if(dateGroup[x].className.indexOf('date-selected')!=-1){
                                        dateGroup[x].classList.remove('date-selected');
                                    }
                                    //如果存在选中日期加样式
                                    if(_this.selDates.length>0){
                                        var str = dateGroup[x].getAttribute('data-date');
                                        if(str == _this.selDates[0]){
                                            dateGroup[x].classList.add('date-selected');
                                        }
                                    }
                                }else{
                                    dateGroup[x].innerHTML ='';
                                    dateGroup[x].classList.add('date-disabled');
                                }
                            }
                        }
                    }
                }else{ //双日历情况
                    var ny,nm;
                    if(parseInt(mm+1)>12){
                        if(parseInt(mm+1)%12 == 0){
                            nm = 12;
                            ny = yy+parseInt((mm+1)/12)-1;
                        }else{
                            nm = parseInt(mm+1)%12;
                            ny = yy+parseInt((mm+1)/12);
                        }
                    }else{
                        nm = mm+1;
                        ny = yy;
                    }
                    var week = new Date(yy+'/'+mm+'/'+'1').getDay();//当月1号星期几
                    var nweek = new Date(ny+'/'+nm+'/'+'1').getDay();//下月1号星期几
                    var curDates = dateList[mm-1]; //当月天数
                    var ncurDates = dateList[nm-1]; //下月份天数
    
                    // 左右版块日期内容
                    var panels = this.panelEls.querySelectorAll('.jm-panel');
                    if(panels.length>0){
                        for(var i=0; i<panels.length; i++){
                            (function(index){
                                if(index == 0){
                                    // 设置头部年月
                                    panels[index].querySelector('.yy-txt').innerHTML = yy;
                                    panels[index].querySelector('.mm-txt').innerHTML = mm;
    
                                    var dateGroup = panels[index].querySelectorAll('.jm-date-box');
                                    if(dateGroup.length>0){
                                        for(var x=0; x<dateGroup.length; x++){
                                            if(x<week){
                                                dateGroup[x].innerHTML ='';
                                                dateGroup[x].classList.add('date-disabled');
                                                if(dateGroup[x].getAttribute('data-date')!=''){
                                                    dateGroup[x].removeAttribute('data-date');
                                                }
    
                                                if(dateGroup[x].className.indexOf('date-selected')!=-1){
                                                    dateGroup[x].classList.remove('date-selected');
                                                    dateGroup[x].removeAttribute('data-date');
                                                }
                                            }else{
                                                if(x-week+1<curDates || x-week+1 == curDates){
                                                    var childTmp = '<p class="sel-label"></p>';
                                                    childTmp+= '<p class="fes-txt">'+_this.setFestText(mm, parseInt(x-week+1))+'</p>';
                                                    childTmp+= '<p class="date-num">'+parseInt(x-week+1)+'</p>';
                                                    dateGroup[x].innerHTML = childTmp;
                                                    dateGroup[x].setAttribute('data-date',yy+'/'+mm+'/'+parseInt(x-week+1));
    
                                                    if(dateGroup[x].className.indexOf('date-disabled')!=-1){
                                                        dateGroup[x].classList.remove('date-disabled');
                                                    }
                                                    
                                                    // 判断获得真实的月份
                                                    var _curM = new Date().getMonth()+1;
                                                    if(_curM>12){
                                                        if(_curM%12 == 0){
                                                            _curM = 12;
                                                        }else{
                                                            _curM = _curM%12;
                                                        }
                                                    }
    
                                                    // 设置过去日期为灰色
                                                    if(yy == _this.curYear){
                                                        if(mm == _curM){
                                                            if(parseInt(x-week+1)<_this.curDate){
                                                                dateGroup[x].classList.add('date-past');
                                                            }else{
                                                                if(dateGroup[x].className.indexOf('date-past')!=-1){
                                                                    dateGroup[x].classList.remove('date-past');
                                                                }
                                                            }
                                                        }else{
                                                            if(dateGroup[x].className.indexOf('date-past')!=-1){
                                                                dateGroup[x].classList.remove('date-past');
                                                            }
                                                        }
                                                    }else{
                                                        if(dateGroup[x].className.indexOf('date-past')!=-1){
                                                            dateGroup[x].classList.remove('date-past');
                                                        }
                                                    }
    
                                                }else{
                                                    dateGroup[x].innerHTML ='';
                                                    dateGroup[x].classList.add('date-disabled');
    
                                                    if(dateGroup[x].getAttribute('data-date')!=''){
                                                        dateGroup[x].removeAttribute('data-date');
                                                    }
    
                                                    if(dateGroup[x].className.indexOf('date-selected')!=-1){
                                                        dateGroup[x].classList.remove('date-selected');
                                                        dateGroup[x].removeAttribute('data-date');
                                                    }
                                                }
                                            }
                                        }
                                    }
                                }else{
                                    // 设置头部年月
                                    panels[index].querySelector('.yy-txt').innerHTML = ny;
                                    panels[index].querySelector('.mm-txt').innerHTML = nm;
    
                                    var dateGroup = panels[index].querySelectorAll('.jm-date-box');
                                    if(dateGroup.length>0){
                                        for(var x=0; x<dateGroup.length; x++){
                                            if(x<nweek){
                                                dateGroup[x].innerHTML ='';
                                                dateGroup[x].classList.add('date-disabled');
    
                                                if(dateGroup[x].getAttribute('data-date')!=''){
                                                    dateGroup[x].removeAttribute('data-date');
                                                }
    
                                                if(dateGroup[x].className.indexOf('date-selected')!=-1){
                                                    dateGroup[x].classList.remove('date-selected');
                                                    dateGroup[x].removeAttribute('data-date');
                                                }
                                            }else{
                                                if(x-nweek+1<ncurDates || x-nweek+1 == ncurDates){
                                                    var childTmp = '<p class="sel-label"></p>';
                                                    childTmp+= '<p class="fes-txt">'+_this.setFestText(nm, parseInt(x-nweek+1))+'</p>';
                                                    childTmp+= '<p class="date-num">'+parseInt(x-nweek+1)+'</p>';
                                                    dateGroup[x].innerHTML = childTmp;
                                                    dateGroup[x].setAttribute('data-date',ny+'/'+nm+'/'+parseInt(x-nweek+1));
    
                                                    if(dateGroup[x].className.indexOf('date-disabled')!=-1){
                                                        dateGroup[x].classList.remove('date-disabled');
                                                    }
    
                                                    // 判断获得真实的月份
                                                    var _curM = new Date().getMonth()+1;
                                                    if(_curM>12){
                                                        if(_curM%12 == 0){
                                                            _curM = 12;
                                                        }else{
                                                            _curM = _curM%12;
                                                        }
                                                    }
    
                                                    // 设置过去日期为灰色
                                                    if(ny == _this.curYear){
                                                        if(nm == _curM){
                                                            if(parseInt(x-nweek+1)<_this.curDate){
                                                                dateGroup[x].classList.add('date-past');
                                                            }else{
                                                                if(dateGroup[x].className.indexOf('date-past')!=-1){
                                                                    dateGroup[x].classList.remove('date-past');
                                                                }
                                                            }
                                                        }else{
                                                            if(dateGroup[x].className.indexOf('date-past')!=-1){
                                                                dateGroup[x].classList.remove('date-past');
                                                            }
                                                        }
                                                    }else{
                                                        if(dateGroup[x].className.indexOf('date-past')!=-1){
                                                            dateGroup[x].classList.remove('date-past');
                                                        }
                                                    }
    
                                                }else{
                                                    dateGroup[x].innerHTML ='';
                                                    dateGroup[x].classList.add('date-disabled');
                                                    if(dateGroup[x].getAttribute('data-date')!=''){
                                                        dateGroup[x].removeAttribute('data-date');
                                                    }
                                                    if(dateGroup[x].className.indexOf('date-selected')!=-1){
                                                        dateGroup[x].classList.remove('date-selected');
                                                        dateGroup[x].removeAttribute('data-date');
                                                    }
                                                }
                                            }
                                        }
                                    }
                                }
                            })(i)
                        }
                    }
    
                    //设置选中的日期或清除选中样式
                    var nSelArr =[];
                    var dateAll = this.panelEls.querySelectorAll('.jm-date-box');
                    if(dateAll.length>0){
                        if(_this.mode == 'range'){ //多选的情况
                            for(var k=0; k<dateAll.length; k++){
                                (function(index){
                                    if(dateAll[index].className.indexOf('date-sel-start')!=-1){
                                        dateAll[index].classList.remove('date-sel-start');
                                    }
                                    if(dateAll[index].className.indexOf('date-sel-end')!=-1){
                                        dateAll[index].classList.remove('date-sel-end');
                                    }
                                    if(dateAll[index].className.indexOf('date-sel-passed')!=-1){
                                        dateAll[index].classList.remove('date-sel-passed');
                                    }
    
                                    
                                    if(_this.selDates.length>0 && _this.selArea.length>0){
                                        var arr = _this.selDates[0];
                                        var brr = _this.selDates[1];
                                        var dateStr = dateAll[index].getAttribute('data-date');
                                        var selLabel = dateAll[index].querySelector('.sel-label');
                                        
                                        if(dateStr == arr){ //当前日期与开始日期相同
                                            dateAll[index].classList.add('date-sel-start');
                                            if(_this.selLabels.length>0){
                                                selLabel.innerHTML = _this.selLabels[0];
                                            }
                                            nSelArr.push(index);
                                        }else if(dateStr == brr){//当前日期与结束日期相同
                                            dateAll[index].classList.add('date-sel-end');
                                            if(_this.selLabels.length>0){
                                                selLabel.innerHTML = _this.selLabels[1];
                                            }
                                            nSelArr.push(index);
                                        }else{
                                            if(dateAll[index].className.indexOf('date-sel-start')!=-1){
                                                dateAll[index].classList.remove('date-sel-start');
                                            }
                                            if(dateAll[index].className.indexOf('date-sel-end')!=-1){
                                                dateAll[index].classList.remove('date-sel-end');
                                            }
                                        }
                                    }
                                    
                                })(k)
                            }
                            //设置选中区域样式
                            for(var x=0; x<dateAll.length; x++){
                                (function(ind){
                                    if(ind>nSelArr[0] && ind<nSelArr[1]){
                                        dateAll[ind].classList.add('date-sel-passed');
                                    }
                                })(x)
                            }
                        }else{ //单选的情况
                            for(var i=0; i<dateAll.length; i++){
                                (function(index){
                                    if(dateAll[index].className.indexOf('date-selected')!=-1){
                                        dateAll[index].classList.remove('date-selected');
                                    }
    
                                    for(var s=0; s<dateAll.length; s++){
                                        var _d = dateAll[s].getAttribute('data-date');
                                        var label = dateAll[s].querySelector('.sel-label');
                                        if(_this.selDates.length>0){
                                            if(_d == _this.selDates[0]){
                                                dateAll[s].classList.add('date-selected');
    
                                                var fes = dateAll[s].querySelector('.fes-txt');
                                                if(fes!=null){
                                                    fes.classList.add('none');
                                                }
                                                if(_this.selLabels.length>0){
                                                    if(label!=null){
                                                        label.innerHTML = _this.selLabels[0];
                                                    }
                                                }
                                            }
                                        }
                                    }
                                })(i)
                            }
                        }
                    }
    
    
                }
            },
            //判断闰平年
            isLeapYear: function(year){
                if(year%4==0&&year%100!=0||year%400==0){
                    return true;
              }else{
                    return false;
                }
            },
            //设置节日
            setFestText:function(fmonth,fdate){
                var gregorianFestivals = {
                    '0101': '元旦',
                    '0214': '情人节',
                    '0308': '妇女节',
                    '0312': '植树节',
                    '0401': '愚人节',
                    '0501': '劳动节',
                    '0504': '青年节',
                    '0512': '护士节',
                    '0601': '儿童节',
                    '0701': '建党节',
                    '0801': '建军节',
                    '0910': '教师节',
                    '1001': '国庆节',
                    '1224': '平安夜',
                    '1225': '圣诞节',
                };
                if(fmonth<10){
                    fmonth = '0'+fmonth;
                }
                if(fdate<10){
                    fdate = '0'+fdate;
                }
                var str = fmonth+fdate;
                if(gregorianFestivals[str] != undefined){
                    return gregorianFestivals[str];
                }else{
                    return '';
                }
            },
            //绑定事件
            bindEvent: function(){
                var _this = this;
    
                //上一月
                this.prevBtn.addEventListener('click',function(e){
                    e.stopPropagation();
                    if(_this.prevBtn.className.indexOf('jm-control-disabled') == -1){
                        _this.curMonth-=1;
    
                        if(_this.curMonth == new Date().getMonth()+1){
                            _this.prevBtn.classList.add('jm-control-disabled');
                        }
    
                        if(_this.curMonth+1>new Date().getMonth()+1){
                            _this.refresh();
                        }
                    }
                });
    
                //下一月
                this.nextBtn.addEventListener('click',function(e){
                    e.stopPropagation();
                    if(_this.nextBtn.className.indexOf('jm-control-disabled') == -1){
                        _this.curMonth+=1;
                        _this.refresh();
                    }
                    if(_this.prevBtn.className.indexOf('jm-control-disabled') !=-1){
                        _this.prevBtn.classList.remove('jm-control-disabled');
                    }
                });
    
                //日期点击
                var _selStNum; //选中开始下标
                var isSelStart = false;
                var isSelEnd = false;
                var dateBoxList = this.panelEls.querySelectorAll('.jm-date-box');
                if(dateBoxList.length>0){
                    for(var i=0; i<dateBoxList.length; i++){
                        (function(index){
                            //鼠标点击
                            dateBoxList[index].addEventListener('click',function(e){
                                e.stopPropagation();
                                if(_this.mode == 'single'){ //日历单选情况
                                    for(var j=0; j<dateBoxList.length; j++){
                                        if(dateBoxList[j].className.indexOf('date-selected')!=-1){
                                            dateBoxList[j].classList.remove('date-selected');
                                        }
                                        var fes = dateBoxList[j].querySelector('.fes-txt');
                                        if(fes!=null){
                                            if(fes.className.indexOf('none')!=-1){
                                                fes.classList.remove('none');
                                            }
                                        }
                                    }
                                    if(dateBoxList[index].className.indexOf('date-selected')==-1){
                                        if(dateBoxList[index].className.indexOf('date-past')==-1){
                                            if(dateBoxList[index].className.indexOf('date-disabled')==-1){
                                                dateBoxList[index].classList.add('date-selected');
                                                dateBoxList[index].querySelector('.fes-txt').classList.add('none');
    
                                                //如果存在选中的日期,数组清空
                                                if(_this.selDates.length>0){_this.selDates=[]};
                                                var _date = dateBoxList[index].getAttribute('data-date');
                                                _this.selDates.push(_date);
    
                                                if(_this.selLabels.length>0){
                                                    var label = dateBoxList[index].querySelector('.sel-label');
                                                    label.innerHTML = _this.selLabels[0];
                                                }
                                                _this.onSelection(_this.selDates);
                                            }
                                        }
                                    }
                                }else{ //选区日历情况
    
                                    if(!isSelStart && !isSelEnd){ //去程和回程都未选
    
                                        for(var j=0; j<dateBoxList.length; j++){
                                            if(dateBoxList[j].className.indexOf('date-sel-start')!=-1){
                                                dateBoxList[j].classList.remove('date-sel-start');
                                                dateBoxList[j].querySelector('.sel-label').innerHTML='';
                                            }
                                            if(dateBoxList[j].className.indexOf('date-sel-end')!=-1){
                                                dateBoxList[j].classList.remove('date-sel-end');
                                                dateBoxList[j].querySelector('.sel-label').innerHTML='';
                                            }
                                            if(dateBoxList[j].className.indexOf('date-sel-passed')!=-1){
                                                dateBoxList[j].classList.remove('date-sel-passed');
                                                dateBoxList[j].querySelector('.sel-label').innerHTML='';
                                            }
                                            var fes = dateBoxList[j].querySelector('.fes-txt');
                                            if(fes!=null){
                                                if(fes.className.indexOf('none')!=-1){
                                                    fes.classList.remove('none');
                                                }
                                            }
                                        }
                                        //选中去程加样式
                                        if(dateBoxList[index].className.indexOf('date-disabled')==-1){
                                            if(dateBoxList[index].className.indexOf('date-past')==-1){
                                                if(dateBoxList[index].className.indexOf('date-sel-passed')!=-1){
                                                    dateBoxList[index].classList.remove('date-sel-passed');
                                                }
                                                dateBoxList[index].classList.add('date-sel-start');
    
                                                var fes = dateBoxList[index].querySelector('.fes-txt');
                                                if(fes!=null){
                                                    fes.classList.add('none');
                                                }
    
                                                //去程标签加文字
                                                var label = dateBoxList[index].querySelector('.sel-label');
                                                if(_this.selLabels.length>0){
                                                    label.innerHTML = _this.selLabels[0];
                                                }
                                                //将去程日期加到数组
                                                if(_this.selDates.length==0){
                                                    var stDate = dateBoxList[index].getAttribute('data-date');
                                                    _this.selDates.push(stDate);
                                                    // console.log(_this.selDates)
                                                }
                                                _selStNum = index;
                                                isSelStart = true;
                                                isSelEnd = false;
                                            }
                                        }
    
                                    }else{ 
    
                                        if(!isSelEnd){ //去程已选且回程未选
    
                                            //选中回程加样式
                                            if(dateBoxList[index].className.indexOf('date-disabled')==-1){
                                                if(dateBoxList[index].className.indexOf('date-past')==-1){
                                                    if(index>_selStNum){
                                                        if(dateBoxList[index].className.indexOf('date-sel-passed')!=-1){
                                                            dateBoxList[index].classList.remove('date-sel-passed');
                                                        }
                                                        dateBoxList[index].classList.add('date-sel-end');
    
                                                        var fes = dateBoxList[index].querySelector('.fes-txt');
                                                        if(fes!=null){
                                                            fes.classList.add('none');
                                                        }
    
                                                        //回程标签加文字
                                                        var label = dateBoxList[index].querySelector('.sel-label');
                                                        if(_this.selLabels.length>0){
                                                            label.innerHTML = _this.selLabels[1];
                                                        }
    
                                                        //设置选区中间日期样式
                                                        for(var k=0; k<dateBoxList.length; k++){
                                                            if(k<index && k>_selStNum){
                                                                if(dateBoxList[k].className.indexOf('date-disabled')==-1){
                                                                    dateBoxList[k].classList.add('date-sel-passed');
                                                                    dateBoxList[k].querySelector('.sel-label').innerHTML='';
                                                                }
                                                            }
                                                        }
    
                                                        //选中的往返日期添加到数组
                                                        if(_this.selDates.length>0){
                                                            var stDate = dateBoxList[_selStNum].getAttribute('data-date');
                                                            var ndDate = dateBoxList[index].getAttribute('data-date');
                                                            _this.selDates[0] = stDate;
                                                            _this.selDates[1] = ndDate;
                                                            // console.log(_this.selDates)
                                                        }
                                                        //选中的往返日期下标加到选区数组
                                                        _this.selArea.push(_selStNum,index);
    
                                                    }else{ //判断下标大小并互换类名
                                                        dateBoxList[index].classList.add('date-sel-start');
                                                        dateBoxList[_selStNum].classList.add('date-sel-end');
    
                                                        if(dateBoxList[index].className.indexOf('date-sel-passed')!=-1){
                                                            dateBoxList[index].classList.remove('date-sel-passed');
                                                        }
    
                                                        var fes = dateBoxList[index].querySelector('.fes-txt');
                                                        if(fes!=null){
                                                            fes.classList.add('none');
                                                        }
    
                                                        //去程标签加文字
                                                        var label = dateBoxList[index].querySelector('.sel-label');
                                                        var label2 = dateBoxList[_selStNum].querySelector('.sel-label');
                                                        if(_this.selLabels.length>0){
                                                            label.innerHTML = _this.selLabels[0];
                                                            label2.innerHTML = _this.selLabels[1];
                                                        }
    
                                                        //设置选区中间日期样式
                                                        for(var k=0; k<dateBoxList.length; k++){
                                                            if(k<_selStNum && k>index){
                                                                if(dateBoxList[k].className.indexOf('date-disabled')==-1){
                                                                    dateBoxList[k].classList.add('date-sel-passed');
                                                                }
                                                            }
                                                        }
    
                                                        //选中的往返日期添加到数组
                                                        if(_this.selDates.length>0){
                                                            var stDate = dateBoxList[index].getAttribute('data-date');
                                                            var ndDate = dateBoxList[_selStNum].getAttribute('data-date');
                                                            _this.selDates[0] = stDate;
                                                            _this.selDates[1] = ndDate;
                                                            // console.log(_this.selDates)
                                                        }
                                                        //选中的往返日期下标加到选区数组
                                                        _this.selArea.push(index,_selStNum);
    
                                                    }
                                                    // console.log(index, _selStNum)
                                                    // console.log(_this)
                                                    isSelStart = true;
                                                    isSelEnd = true;
                                                    _this.onSelection(_this.selDates);
                                                }
                                            }
    
                                        }else{ //去程和回程都已选
    
                                            for(var j=0; j<dateBoxList.length; j++){
                                                if(dateBoxList[j].className.indexOf('date-sel-start')!=-1){
                                                    dateBoxList[j].classList.remove('date-sel-start');
                                                    dateBoxList[j].querySelector('.sel-label').innerHTML='';
                                                }
                                                if(dateBoxList[j].className.indexOf('date-sel-end')!=-1){
                                                    dateBoxList[j].classList.remove('date-sel-end');
                                                    dateBoxList[j].querySelector('.sel-label').innerHTML='';
                                                }
                                                if(dateBoxList[j].className.indexOf('date-sel-passed')!=-1){
                                                    dateBoxList[j].classList.remove('date-sel-passed');
                                                    dateBoxList[j].querySelector('.sel-label').innerHTML='';
                                                }
                                                var fes = dateBoxList[j].querySelector('.fes-txt');
                                                if(fes!=null){
                                                    if(fes.className.indexOf('none')!=-1){
                                                        fes.classList.remove('none');
                                                    }
                                                }
                                            }
                                            //选中去程加样式
                                            if(dateBoxList[index].className.indexOf('date-disabled')==-1){
                                                if(dateBoxList[index].className.indexOf('date-past')==-1){
                                                    dateBoxList[index].classList.add('date-sel-start');
    
                                                    var fes = dateBoxList[index].querySelector('.fes-txt');
                                                    if(fes!=null){
                                                        fes.classList.add('none');
                                                    }
    
                                                    //去程标签加文字
                                                    var label = dateBoxList[index].querySelector('.sel-label');
                                                    if(_this.selLabels.length>0){
                                                        label.innerHTML = _this.selLabels[0];
                                                    }
                                                    //将去程日期加到数组
                                                    if(_this.selDates.length>0){
                                                        _this.selDates =[];
                                                        var stDate = dateBoxList[index].getAttribute('data-date');
                                                        _this.selDates.push(stDate);
                                                    }
                                                    _selStNum = index;
                                                    isSelStart = true;
                                                    isSelEnd = false;
                                                }
                                            }
                                        }
                                    }
                                }
                            });
                            
                            //鼠标经过
                            dateBoxList[index].addEventListener('mouseover', function(){
                                if(_this.mode == 'range'){
                                    if(_this.selDates.length == 1){
                                        if(dateBoxList[index].className.indexOf('date-disabled')!=-1){
                                            return false;
                                        }
                                        if(dateBoxList[index].className.indexOf('date-past')!=-1){
                                            return false;
                                        }
                                        if(dateBoxList[index].className.indexOf('date-sel-start')!=-1){
                                            return false;
                                        }
                                        if(dateBoxList[index].className.indexOf('date-sel-end')!=-1){
                                            dateBoxList[index].classList.remove('date-sel-passed');
                                            return false;
                                        }
                                        
                                        //开始日期与经过日期
                                        var d1 = new Date(_this.selDates[0]).getTime();
                                        var d2 = new Date(dateBoxList[index].getAttribute('data-date')).getTime();
    
                                        var overlist = _this.panelEls.querySelectorAll('.jm-date-box');
                                        for(var z=0; z<overlist.length; z++){
                                            (function(ind){
                                                if(d1<d2){ //开始日期小于经过日期
                                                    var d3 = new Date(overlist[ind].getAttribute('data-date')).getTime();
                                                    if(d3>d1 && d3<d2 || d3 == d2){
                                                        for(var k=0; k<overlist.length; k++){
                                                            var _d4 = new Date(overlist[k].getAttribute('data-date')).getTime();
                                                            if(_d4<d1){
                                                                if(overlist[k].className.indexOf('date-sel-passed')!=-1){
                                                                    overlist[k].classList.remove('date-sel-passed');
                                                                }
                                                            }
                                                            if(_d4>d2){
                                                                if(overlist[k].className.indexOf('date-sel-passed')!=-1){
                                                                    overlist[k].classList.remove('date-sel-passed');
                                                                }
                                                            }
                                                        }
                                                        if(overlist[ind].className.indexOf('date-sel-end') == -1){
                                                            overlist[ind].classList.add('date-sel-passed');
                                                        }else{
                                                            return false;
                                                        }
                                                    }
                                                }else{
                                                    var d3 = new Date(overlist[ind].getAttribute('data-date')).getTime();
                                                    if(d3>d2 && d3<d1 || d3 == d2){
                                                        for(var k=0; k<overlist.length; k++){
                                                            var _d4 = new Date(overlist[k].getAttribute('data-date')).getTime();
                                                            if(_d4>d1){
                                                                if(overlist[k].className.indexOf('date-sel-passed')!=-1){
                                                                    overlist[k].classList.remove('date-sel-passed');
                                                                }
                                                            }
                                                            if(_d4<d2){
                                                                if(overlist[k].className.indexOf('date-sel-passed')!=-1){
                                                                    overlist[k].classList.remove('date-sel-passed');
                                                                }
                                                            }
                                                        }
                                                        if(overlist[ind].className.indexOf('date-sel-end') == -1){
                                                            overlist[ind].classList.add('date-sel-passed');
                                                        }else{
                                                            return false;
                                                        }
                                                        if(overlist[ind].className.indexOf('date-sel-start') == -1){
                                                            overlist[ind].classList.add('date-sel-passed');
                                                        }else{
                                                            return false;
                                                        }
                                                    }
                                                }
    
                                            })(z)
                                        }
                                        
                                    }
                                }
                            });
    
                        })(i)
                    }
                }
            },
            //选中的回调函数
            onSelection: function(arr){
                var _this = this;
                if(_this.selectionType === 'callback'){
                    _this.onSelection.call(_this);
                }else{
                    _this.hide();
                }
            },
            //隐藏弹层
            hide: function (){
                var _this = this;
                _this.rootTmp.classList.add('jm-datepicker-hide');
            },
            //隐藏显示
            show: function(){
                var _this = this;
                if(_this.rootTmp.className.indexOf('jm-datepicker-hide')!=-1){
                    _this.rootTmp.classList.remove('jm-datepicker-hide');
                }
            },
        }
        return datePicker;
    })()
    View Code

    欢迎下载,给个star鼓励一下,谢谢。

    https://github.com/lcy20150720/datepicker.git

  • 相关阅读:
    windows下用python转换markdown到html
    windows下安装pip和easy_install
    Getting Real 摘记
    使iis支持asp.net扩展
    Linux IO模型
    kdissert:linux下的自由脑图软件
    debian下配置双核cpu
    内核:为了fan的健康,我的重新编译记录
    科研在每个人的生活中
    Donald Ervin Knuth:最年轻的图灵奖高德纳
  • 原文地址:https://www.cnblogs.com/cyppi/p/13565536.html
Copyright © 2011-2022 走看看