转载自:http://blog.csdn.net/sp308036654/article/details/50638348

<input type="text" class="time hotelDepartrue" datefmt="yyyy-MM-dd" onchange="checkDate('endDate')"/>
1:找到dwz.datepicker.js文件
2:在下面的文件中,把红色的部分添加进去
/**
 * reference dwz.util.date.js
 * @author ZhangHuihua@msn.com
 * 
 */
(function($){
    $.setRegional("datepicker", {
        dayNames:['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
        monthNames:['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
    });
 
    $.fn.datepicker = function(opts){
        var setting = {
            box$:"#calendar",
            year$:"#calendar [name=year]", month$:"#calendar [name=month]",
            tmInputs$:"#calendar .time :text", hour$:"#calendar .time .hh", minute$:"#calendar .time .mm", second$:"#calendar .time .ss",
            tmBox$:"#calendar .tm", tmUp$:"#calendar .time .up", tmDown$:"#calendar .time .down",
            close$:"#calendar .close", calIcon$:"a.inputDateButton",
            main$:"#calendar .main", days$:"#calendar .days", dayNames$:"#calendar .dayNames",
            clearBut$:"#calendar .clearBut", okBut$:"#calendar .okBut"
        };
 
        function changeTmMenu(sltClass){
            var $tm = $(setting.tmBox$);
            $tm.removeClass("hh").removeClass("mm").removeClass("ss");
            if (sltClass) {
                $tm.addClass(sltClass);
                $(setting.tmInputs$).removeClass("slt").filter("." + sltClass).addClass("slt");
            }
        }
        function clickTmMenu($input, type){
            $(setting.tmBox$).find("."+type+" li").each(function(){
                var $li = $(this);
                $li.click(function(){
                    $input.val($li.text());
                });
            });
        }
        function keydownInt(e){
            if (!((e.keyCode >= 48 && e.keyCode <= 57) || (e.keyCode == DWZ.keyCode.DELETE || e.keyCode == DWZ.keyCode.BACKSPACE))) { return false; }
        }
        function changeTm($input, type){
            var ivalue = parseInt($input.val()), istart = parseInt($input.attr("start")) || 0, iend = parseInt($input.attr("end"));
            var istep = parseInt($input.attr('step') || 1);
            if (type == 1) {
                if (ivalue <= iend-istep){$input.val(ivalue + istep);}
            } else if (type == -1){
                if (ivalue >= istart+istep){$input.val(ivalue - istep);}
            } else if (ivalue > iend) {
                $input.val(iend);
            } else if (ivalue < istart) {
                $input.val(istart);
            }
        }
 
        return this.each(function(){
            var $this = $(this);
            var dp = new Datepicker($this.val(), opts);
 
            function generateCalendar(dp){
                var dw = dp.getDateWrap();
                var minDate = dp.getMinDate();
                var maxDate = dp.getMaxDate();
 
                var monthStart = new Date(dw.year,dw.month-1,1);
                var startDay = monthStart.getDay();
                var dayStr="";
                if (startDay > 0){
                    monthStart.setMonth(monthStart.getMonth() - 1);
                    var prevDateWrap = dp.getDateWrap(monthStart);
                    for(var t=prevDateWrap.days-startDay+1;t<=prevDateWrap.days;t++) {
                        var _date = new Date(dw.year,dw.month-2,t);
                        var _ctrClass = (_date >= minDate && _date <= maxDate) ? '' : 'disabled';
                        dayStr+='<dd class="other '+_ctrClass+'" chMonth="-1" day="' + t + '">'+t+'</dd>';
                    }
                }
                for(var t=1;t<=dw.days;t++){
                    var _date = new Date(dw.year,dw.month-1,t);
                    var _ctrClass = (_date >= minDate && _date <= maxDate) ? '' : 'disabled';
                    if(t==dw.day){
                        dayStr+='<dd class="slt '+_ctrClass+'" day="' + t + '">'+t+'</dd>';
                    }else{
                        dayStr+='<dd class="'+_ctrClass+'" day="' + t + '">'+t+'</dd>';
                    }
                }
                for(var t=1;t<=42-startDay-dw.days;t++){
                    var _date = new Date(dw.year,dw.month,t);
                    var _ctrClass = (_date >= minDate && _date <= maxDate) ? '' : 'disabled';
                    dayStr+='<dd class="other '+_ctrClass+'" chMonth="1" day="' + t + '">'+t+'</dd>';
                }
 
                var $days = $(setting.days$).html(dayStr).find("dd");
                $days.not('.disabled').click(function(){
                    var $day = $(this);
 
                    if (!dp.hasTime()) {
                        $this.val(dp.formatDate(dp.changeDay($day.attr("day"), $day.attr("chMonth"))));
                        // 添加监听日期改变(PineTree添加)
                        $this.change();
                        closeCalendar(); 
                    } else {
                        $days.removeClass("slt");
                        $day.addClass("slt");
                    }
                });
 
                if (!dp.hasDate()) $(setting.main$).addClass('nodate'); // 仅时间,无日期
 
                if (dp.hasTime()) {
                    $("#calendar .time").show();
 
                    var $hour = $(setting.hour$).val(dw.hour).focus(function(){
                        changeTmMenu("hh");
                    });
                    var iMinute = parseInt(dw.minute / dp.opts.mmStep) * dp.opts.mmStep;
                    var $minute = $(setting.minute$).val(iMinute).attr('step',dp.opts.mmStep).focus(function(){
                        changeTmMenu("mm");
                    });
                    var $second = $(setting.second$).val(dp.hasSecond() ? dw.second : 0).attr('step',dp.opts.ssStep).focus(function(){
                        changeTmMenu("ss");
                    });
 
                    $hour.add($minute).add($second).click(function(){return false});
 
                    clickTmMenu($hour,"hh");
                    clickTmMenu($minute,"mm");
                    clickTmMenu($second,"ss");
                    $(setting.box$).click(function(){
                        changeTmMenu();
                    });
 
                    var $inputs = $(setting.tmInputs$);
                    $inputs.keydown(keydownInt).each(function(){
                        var $input = $(this);
                        $input.keyup(function(){
                            changeTm($input, 0);
                        });
                    });
                    $(setting.tmUp$).click(function(){
                        $inputs.filter(".slt").each(function(){
                            changeTm($(this), 1);
                        });
                    });
                    $(setting.tmDown$).click(function(){
                        $inputs.filter(".slt").each(function(){
                            changeTm($(this), -1);
                        });
                    });
 
                    if (!dp.hasHour()) $hour.attr("disabled",true);
                    if (!dp.hasMinute()) $minute.attr("disabled",true);
                    if (!dp.hasSecond()) $second.attr("disabled",true);
                }
 
            }
 
            function closeCalendar() {
                $(setting.box$).remove();
                $(document).unbind("click", closeCalendar);
            }
 
            $this.click(function(event){
                closeCalendar();
                var dp = new Datepicker($this.val(), opts);
                var offset = $this.offset();
                var iTop = offset.top+this.offsetHeight;
                $(DWZ.frag['calendarFrag']).appendTo("body").css({
                    left:offset.left+'px',
                    top:iTop+'px'
                }).show().click(function(event){
                    event.stopPropagation();
                });
 
                ($.fn.bgiframe && $(setting.box$).bgiframe());
 
                var dayNames = "";
                $.each($.regional.datepicker.dayNames, function(i,v){
                    dayNames += "<dt>" + v + "</dt>"
                });
                $(setting.dayNames$).html(dayNames);
 
                var dw = dp.getDateWrap();
                var $year = $(setting.year$);
                var yearstart = dp.getMinDate().getFullYear();
                var yearend = dp.getMaxDate().getFullYear();
                for(y=yearstart; y<=yearend; y++){
                    $year.append('<option value="'+ y +'"'+ (dw.year==y ? 'selected="selected"' : '') +'>'+ y +'</option>');
                }
                var $month = $(setting.month$);
                $.each($.regional.datepicker.monthNames, function(i,v){
                    var m = i+1;
                    $month.append('<option value="'+ m +'"'+ (dw.month==m ? 'selected="selected"' : '') +'>'+ v +'</option>');
                });
 
                // generate calendar
                generateCalendar(dp);
                $year.add($month).change(function(){
                    dp.changeDate($year.val(), $month.val());
                    generateCalendar(dp);
                });
 
                // fix top
                var iBoxH = $(setting.box$).outerHeight(true);
                if (iTop > iBoxH && iTop > $(window).height()-iBoxH) {
                    $(setting.box$).css("top", offset.top - iBoxH);
                }
 
                $(setting.close$).click(function(){
                    closeCalendar();
                });
                $(setting.clearBut$).click(function(){
                    $this.val("");
                    closeCalendar();
                    // 添加日期改变监听(PineTree添加)
                    $this.change();
                });
                $(setting.okBut$).click(function(){
                    var $dd = $(setting.days$).find("dd.slt");
 
                    if ($dd.hasClass("disabled")) return false;
 
                    var date = dp.changeDay($dd.attr("day"), $dd.attr("chMonth"));
 
                    if (dp.hasTime()) {
                         date.setHours(parseInt($(setting.hour$).val()));
                        date.setMinutes(parseInt($(setting.minute$).val()));
                        date.setSeconds(parseInt($(setting.second$).val()));
                    }
 
                    $this.val(dp.formatDate(date));
                    closeCalendar();
                    // 添加日期改变监听(PineTree添加)
                    $this.change();
                });
                $(document).bind("click", closeCalendar);
                return false;
            });
 
            $this.parent().find(setting.calIcon$).click(function(){
                $this.trigger("click");
                return false;
            });
        });
 
    }
 
    var Datepicker = function(sDate, opts) {
        this.opts = $.extend({
            pattern:'yyyy-MM-dd',
            minDate:"1900-01-01",
            maxDate:"2099-12-31",
            mmStep:1,
            ssStep:1
        }, opts);
 
        //动态minDate、maxDate
        var now = new Date();
        this.opts.minDate = now.formatDateTm(this.opts.minDate);
        this.opts.maxDate = now.formatDateTm(this.opts.maxDate);
 
        this.sDate = sDate.trim();
    }
 
    $.extend(Datepicker.prototype, {
        get: function(name) {
            return this.opts[name];
        },
        _getDays: function (y,m){//获取某年某月的天数
 
            return m==2?(y%4||!(y%100)&&y%400?28:29):(/4|6|9|11/.test(m)?30:31);
        },
 
        _minMaxDate: function(sDate){
            var _count = sDate.split('-').length -1;
            var _format = 'y-M-d';
            if (_count == 1) _format = 'y-M';
            else if (_count == 0) _format = 'y';
 
            return sDate.parseDate(_format);
        },
        getMinDate: function(){
            return this._minMaxDate(this.opts.minDate);
        },
        getMaxDate: function(){
            var _sDate = this.opts.maxDate;
            var _count = _sDate.split('-').length -1;
            var _date = this._minMaxDate(_sDate);
 
            if (_count < 2) { //format:y-M、y
 
                var _day = this._getDays(_date.getFullYear(), _date.getMonth()+1);
                _date.setDate(_day);
                if (_count == 0) {//format:y
 
                    _date.setMonth(11);
                }
            }
 
            return _date;
        },
        getDateWrap: function(date){ //得到年,月,日
 
            if (!date) date = this.parseDate(this.sDate) || new Date();
            var y = date.getFullYear();
            var m = date.getMonth()+1;
            var days = this._getDays(y,m);
            return {
                year:y, month:m, day:date.getDate(),
                hour:date.getHours(),minute:date.getMinutes(),second:date.getSeconds(),
                days: days, date:date
            }
        },
        /**
         * @param {year:2010, month:05, day:24}
         */
        changeDate: function(y, m, d){
            var date = new Date(y, m - 1, d || 1);
            this.sDate = this.formatDate(date);
            return date;
        },
        changeDay: function(day, chMonth){
            if (!chMonth) chMonth = 0;
            var dw = this.getDateWrap();
            return this.changeDate(dw.year, dw.month+parseInt(chMonth), day);
        },
        parseDate: function(sDate){
            if (!sDate) return null;
            return sDate.parseDate(this.opts.pattern);
        },
        formatDate: function(date){
            return date.formatDate(this.opts.pattern);
        },
        hasHour: function() {
            return this.opts.pattern.indexOf("H") != -1;
        },
        hasMinute: function() {
            return this.opts.pattern.indexOf("m") != -1;
        },
        hasSecond: function() {
            return this.opts.pattern.indexOf("s") != -1;
        },
        hasTime: function() {
            return this.hasHour() || this.hasMinute() || this.hasSecond();
        },
        hasDate: function() {
            var _dateKeys = ['y','M','d','E'];
            for (var i=0; i<_dateKeys.length; i++){
                if (this.opts.pattern.indexOf(_dateKeys[i]) != -1) return true;
            }
 
            return false;
        }
    });
})(jQuery);

dwz监听日期变化,dwz日期控件onchange不起作用,dwz框架时间控件不支持onchange事件的更多相关文章

  1. Angular.js中使用$watch监听模型变化

    $watch简单使用 $watch是一个scope函数,用于监听模型变化,当你的模型部分发生变化时它会通知你. $watch(watchExpression, listener, objectEqua ...

  2. $scope.$watch()——监听数据变化

    $scope.$watch(watchFn, watchAction, [deepWatch]):监听数据变化,三个参数 --watchFn:监听的对象,一个带有Angular 表达式或者函数的字符串 ...

  3. 如何使用NodeJs来监听文件变化

    1.前言 在我们调试修改代码的时候,每修改一次代码,哪怕只是很小的修改,我们都需要手动重新build文件,然后再运行代码,看修改的效果,这样的效率特别低,对于开发者来说简直不能忍. 2.构建自动编译工 ...

  4. android动态注册监听网络变化异常

    在使用广播接收器监听网络变化的时候,在AndroidManifest.xml中加入<user-permission android:name="android.permission.A ...

  5. Android 监听网络变化

    Android 监听网络变化

  6. --@angularJS--$scope.watch监听模型变化

    $watch简单使用 $watch是一个scope函数,用于监听模型变化,当你的模型部分发生变化时它会通知你. $watch(watchExpression, listener, objectEqua ...

  7. vue.js之过滤器,自定义指令,自定义键盘信息以及监听数据变化

    一.监听数据变化 1.监听数据变化有两种,深度和浅度,形式如下: vm.$watch(name,fnCb); //浅度 vm.$watch(name,fnCb,{deep:true}); //深度监视 ...

  8. webview缓存及跳转时截取url地址、监听页面变化

    缓存及一些设定 我在做一些项目时,h5做的项目手机浏览器能使用,但是在搬到webview时候不能用,这个时候通过查阅资料,原来是webview没有设定好,包括缓存.缓存大小及路径等等 mWebview ...

  9. 对于单页应用中如何监听 URL 变化的思考

    周末开发了一个在 GitHub 中给 repo 增加自定义备注的 chrome 扩展. 开发这个扩展的原因是我在 GitHub 中所 star 的项目实在太多了(截止目前 671 个),有的项目过个几 ...

  10. js动态监听dom变化

    原生js 动态监听dom变化,根据不同的类型绑定不同的处理逻辑 // Firefox和Chrome早期版本中带有前缀   var MutationObserver = window.MutationO ...

随机推荐

  1. Centos7环境下安装python3.6.4 并与python2共存

    最近安装了新系统centos7,本身自带python2.7,但是由于需要使用python3 来运行一些应用,所以想到在centos环境下安装python3,并保证其和python2 可以共存. 步骤如 ...

  2. 每天一个linux命令(网络):【转载】ping命令

    Linux系统的ping命令是常用的网络命令,它通常用来测试与目标主机的连通性,我们经常会说“ping一下某机器,看是不是开着”.不能打开网页时会说“你先ping网关地址192.168.1.1试试”. ...

  3. Idea 使用 Maven 搭建 Web 项目

    传送门: 袁咩咩的小小博客 Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具. 使用它来搭建项目可以省去很多操作,它不仅有依赖管理.自动生成项目站 ...

  4. 企业web管理软件开发平台

    可以自定义拖动记忆位置的part桌面 权限(功能菜单查看范围)设置界面 权限(人员数据查看范围)设置界面 菜单排序和名称设置界面 业务模块 自定义字段界面 业务功能  列表界面 业务功能   查询界面 ...

  5. jQuqery append 和 after 区别

    jQuqery append 和 after 区别 append 是在被选元素内的结尾插入内容. 比如以下选中了 ol 元素,使用 append 后会在 <li> List Item 2 ...

  6. RabbitMQ内存爆出问题解决思路

    http://www.bubuko.com/infodetail-2121050.html RabbitMQ升级到3.6.1版本后,随着业务和系统功能的增加,出现RabbitMQ内存陡增直至服务宕掉的 ...

  7. zipkin:HttpClient和struts

    因为要和老系统集成zipkin,意外的发现老系统使用的httpClient来发送信息.zipkin的官方demo可都是retstTemplate啊!有的搞头. 在看Demo的时候意外的发现其实其实2. ...

  8. QT4.8.5环境移植到嵌入式平台

    QT4.8.5环境移植到嵌入式平台 参考:Qt移植到ARM Linux教程 http://www.veryarm.com/930.html 清除配置: sudo make confclean 配置: ...

  9. ASI接口

    Asynchronous Serial Interface ,异步串行接口,用于传送码流的一个标准DVB接口. 在目前的DVB-C系统设备的传输接口有两种MPEG2视频码流传输接口标准:异步串行接口A ...

  10. VS解决方案的目录结构设置和管理

    一个中等规模的解决方案通常都会包含多个项目,其中一些项目产出静态库,一些产出动态库,一些用于单元测试,还有的产出最终的应用程序执行档.除此以外,根据项目的需求,还会使用一些第三方的库.   所以为解决 ...