datepicker 日期連續選擇(須要改源碼)

先上效果:javascript

代碼:css

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>日期選擇</title>
<link rel="stylesheet" href="reset-jquery-ui.min.css" />
<script type="text/javascript" src="jquery-1.8.3.min.js"></script>
<script type="text/javascript" src="jquery-ui.js"></script>
<script type="text/javascript">
//日期選擇
$.datepicker.regional['zh-CN'] = {
    clearText: '清除',
    clearStatus: '清除已選日期',
    closeText: '關閉',
    closeStatus: '不改變當前選擇',
    prevText: '<上月',
    prevStatus: '顯示上月',
    prevBigText: '<<',
    prevBigStatus: '顯示上一年',
    nextText: '下月>',
    nextStatus: '顯示下月',
    nextBigText: '>>',
    nextBigStatus: '顯示下一年',
    currentText: '今天',
    currentStatus: '顯示本月',
    monthNames: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
    monthNamesShort: ['', '', '', '', '', '', '', '', '', '', '十一', '十二'],
    monthStatus: '選擇月份',
    yearStatus: '選擇年份',
    weekHeader: '',
    weekStatus: '年內周次',
    dayNames: ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'],
    dayNamesShort: ['週日', '週一', '週二', '週三', '週四', '週五', '週六'],
    dayNamesMin: ['', '', '', '', '', '', ''],
    dayStatus: '設置 DD 爲一週起始',
    dateStatus: '選擇 m月 d日, DD',
    dateFormat: 'yy-mm-dd',
    firstDay: 1,
    initStatus: '請選擇日期',
    isRTL: false
};
$.datepicker.setDefaults($.datepicker.regional['zh-CN']);

var a = 0;
var tmpdate = "";

/**
  * 實例化日期控件,並綁定回調函數,傳入相應參數
  * tagId 日期控件實例化的標籤id
  * ajaxMethod 回調函數
  * ajaxMethod 函數須要用到的額外參數
  **/
function datePickerById(tagId){
    $(tagId).datepicker( {
        isDataChecked:true,
        autoClose:true,
        showOtherMonths: true,
        changeYear: true,
        //showStatus: true,
        //showOn: "both",
        numberOfMonths:2,//顯示幾個月
        showMonthAfterYear:true,
        onSelect: function(dateText,inst) {//選擇日期後執行的操做
            a++;
            inst.autoClose = true;
            if(a==1){
                inst.settings.isDataChecked = false;
                tmpdate = dateText;
            }
            if(a==2){
                a=0;
                inst.settings.isDataChecked = false;
                inst.autoClose = false;
                var date1 = new Date(tmpdate).getTime();
                var date2 = new Date(dateText).getTime();

                var arg = {time_s:date1,time_e:date2}; //ajax函數要用到的時間參數

                if(date1<date2){
                      $(tagId).val(tmpdate.replace(/-/ig,"-")+""+dateText.replace(/-/ig,"-"));
                  }else if(date1 == date2){
                    a = 1;
                    inst.settings.isDataChecked = false;
                    inst.autoClose = true;
                  }else{
                      $(tagId).val(dateText.replace(/-/ig,"-")+""+tmpdate.replace(/-/ig,"-"));
                  }
            }

        }
    });
}
</script>
</head>
<body>
時間選擇:<input id="div1" style="height:30px;width:190px;"/>
<script type="text/javascript">
datePickerById('#div1');
</script>
</body>
</html>

 

基於jquery UI 1.11.4修改以下(在源碼裏面修改):html

/* Hide the date picker from view.
     * @param  input  element - the input field attached to the date picker
     */
    _hideDatepicker: function(input) {
        var showAnim, duration, postProcess, onClose,
            inst = this._curInst;

        if (!inst || (input && inst !== $.data(input, "datepicker"))) {
            return;
        }
        /**
             * 2015.6.11 修改
             * author:link
             * 增長inst.autoClose控制日曆面板
             */
// -----------------------------------------------------------------------------------------
 if (this._datepickerShowing||!inst.autoClose) { showAnim = this._get(inst, "showAnim"); duration = this._get(inst, "duration"); postProcess = function() { $.datepicker._tidyDialog(inst); }; // DEPRECATED: after BC for 1.8.x $.effects[ showAnim ] is not needed if(inst.autoClose===true){ // 這裏不隱藏 }else{ if ( $.effects && ( $.effects.effect[ showAnim ] || $.effects[ showAnim ] ) ) { inst.dpDiv.hide(showAnim, $.datepicker._get(inst, "showOptions"), duration, postProcess); } else { inst.dpDiv[(showAnim === "slideDown" ? "slideUp" : (showAnim === "fadeIn" ? "fadeOut" : "hide"))]((showAnim ? duration : null), postProcess); } }
// -----------------------------------------------------------------------------------------
if (!showAnim) { postProcess(); } this._datepickerShowing = false; onClose = this._get(inst, "onClose"); if (onClose) { onClose.apply((inst.input ? inst.input[0] : null), [(inst.input ? inst.input.val() : ""), inst]); } this._lastInput = null; if (this._inDialog) { this._dialogInput.css({ position: "absolute", left: "0", top: "-100px" }); if ($.blockUI) { $.unblockUI(); $("body").append(this.dpDiv); } } this._inDialog = false; } },

 

1.11.4修改後完整源碼java

連接:http://pan.baidu.com/s/1bnjQycv 密碼:hr19jquery

相關文章
相關標籤/搜索