js日期控制器(不带时间)

/**
 * Calendar
 * @param   beginYear                                1990
 * @param   endYear                                  2010
 * @param   language                                 0(zh_cn)|1(en_us)|2(en_en)|3(zh_tw)
 * @param   patternDelimiter                       "-"
 * @param   date2StringPattern                    "yyyy-MM-dd"
 * @param   string2DatePattern                    "ymd"
 * @version 1.0 build 2006-04-01
 * @version 1.1 build 2006-12-17
 * @author  martin

 * NOTE!    you can use it free, but keep the copyright please
 * IMPORTANT:you must include this script file inner html body elment
 */
function Calendar(beginYear, endYear, language, patternDelimiter, date2StringPattern, string2DatePattern) {

      this.beginYear = beginYear || 1990;
      this.endYear   = endYear   || 2020;
      this.language  = language  || 0;
      this.patternDelimiter = patternDelimiter     || "-";
      this.date2StringPattern = date2StringPattern || Calendar.language                  ["date2StringPattern"][this.language].replace(//-/g, this.patternDelimiter);
      this.string2DatePattern = string2DatePattern || Calendar.language["string2DatePattern"][this.language];
 
      this.dateControl = null;
      this.panel  = this.getElementById("__calendarPanel");
      this.iframe = window.frames["__calendarIframe"];
      this.form   = null;
 
      this.date = new Date();
      this.year = this.date.getFullYear();
      this.month = this.date.getMonth();
 
      this.colors = {"bg_cur_day":"#00CC33","bg_over":"#EFEFEF","bg_out":"#FFCC00"}
};

Calendar.language = {
      "year"   : ["/u5e74", "", "", "/u5e74"],
      "months" : [
            ["/u4e00/u6708","/u4e8c/u6708","/u4e09/u6708","/u56db/u6708","/u4e94/u6708","/u516d/u6708","/u4e03/u6708","/u516b/u6708","/u4e5d/u6708","/u5341/u6708","/u5341/u4e00/u6708","/u5341/u4e8c/u6708"],
            ["JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"],
            ["JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"],
            ["/u4e00/u6708","/u4e8c/u6708","/u4e09/u6708","/u56db/u6708","/u4e94/u6708","/u516d/u6708","/u4e03/u6708","/u516b/u6708","/u4e5d/u6708","/u5341/u6708","/u5341/u4e00/u6708","/u5341/u4e8c/u6708"] 

      ],
       "weeks"  : [["/u65e5","/u4e00","/u4e8c","/u4e09","/u56db","/u4e94","/u516d"],
            ["Sun","Mon","Tur","Wed","Thu","Fri","Sat"],
            ["Sun","Mon","Tur","Wed","Thu","Fri","Sat"],
            ["/u65e5","/u4e00","/u4e8c","/u4e09","/u56db","/u4e94","/u516d"]
      ],
      "clear"  : ["/u6e05/u7a7a", "Clear", "Clear", "/u6e05/u7a7a"],
      "today"  : ["/u4eca/u5929", "Today", "Today", "/u4eca/u5929"],
      "close"  : ["/u5173/u95ed", "Close", "Close", "/u95dc/u9589"],
      "date2StringPattern" : ["yyyy-MM-dd", "yyyy-MM-dd", "yyyy-MM-dd", "yyyy-MM-dd"],
      "string2DatePattern" : ["ymd","ymd", "ymd", "ymd"]
};

      Calendar.prototype.draw = function() {
            calendar = this;
            var _cs = [];
            _cs[_cs.length] = '<form id="__calendarForm" name="__calendarForm" method="post">';
            _cs[_cs.length] = '<table id="__calendarTable" width="100%" border="0" cellpadding="3" cellspacing="1" align="center">';
            _cs[_cs.length] = ' <tr>';
            _cs[_cs.length] = '  <th><input class="l" name="goPrevMonthButton" type="button" id="goPrevMonthButton" value="&lt;" //><//th>';
            _cs[_cs.length] = '  <th colspan="5"><select class="year" name="yearSelect" id="yearSelect"><//select><select class="month" name="monthSelect" id="monthSelect"><//select><//th>';
            _cs[_cs.length] = '  <th><input class="r" name="goNextMonthButton" type="button" id="goNextMonthButton" value="&gt;" //><//th>';
            _cs[_cs.length] = ' <//tr>';
            _cs[_cs.length] = ' <tr>';
            for(var i = 0; i < 7; i++) {
                  _cs[_cs.length] = '<th class="theader">';
                  _cs[_cs.length] = Calendar.language["weeks"][this.language][i];
                  _cs[_cs.length] = '<//th>'; 
            }
            _cs[_cs.length] = '<//tr>';
            for(var i = 0; i < 6; i++){
                  _cs[_cs.length] = '<tr align="center">';
                  for(var j = 0; j < 7; j++) {
                        switch (j) {
                            case 0: _cs[_cs.length] = '<td class="sun">&nbsp;<//td>'; break;
                            case 6: _cs[_cs.length] = '<td class="sat">&nbsp;<//td>'; break;
                            default:_cs[_cs.length] = '<td class="normal">&nbsp;<//td>'; break;
                        }

                  }
                  _cs[_cs.length] = '<//tr>';
            }
            _cs[_cs.length] = ' <tr>';
            _cs[_cs.length] = '  <th colspan="2"><input type="button" class="b" name="clearButton" id="clearButton" //><//th>';
            _cs[_cs.length] = '  <th colspan="3"><input type="button" class="b" name="selectTodayButton" id="selectTodayButton" //><//th>';
            _cs[_cs.length] = '  <th colspan="2"><input type="button" class="b" name="closeButton" id="closeButton" //><//th>';
            _cs[_cs.length] = ' <//tr>';
            _cs[_cs.length] = '<//table>';
            _cs[_cs.length] = '<//form>';
 
            this.iframe.document.body.innerHTML = _cs.join("");
            this.form = this.iframe.document.forms["__calendarForm"];

            this.form.clearButton.value = Calendar.language["clear"][this.language];
            this.form.selectTodayButton.value = Calendar.language["today"][this.language];
            this.form.closeButton.value = Calendar.language["close"][this.language];
 
            this.form.goPrevMonthButton.onclick = function () {calendar.goPrevMonth(this);}
            this.form.goNextMonthButton.οnclick=function () {calendar.goNextMonth(this);}
            this.form.yearSelect.onchange = function () {calendar.update(this);}
            this.form.monthSelect.onchange = function () {calendar.update(this);}
 
            this.form.clearButton.onclick = function () {calendar.dateControl.value = "";calendar.hide();}
            this.form.closeButton.onclick = function () {calendar.hide();}
            this.form.selectTodayButton.onclick = function () {
            var today = new Date();
            calendar.date = today;
            calendar.year = today.getFullYear();
            calendar.month = today.getMonth();
            calendar.dateControl.value = today.format(calendar.date2StringPattern);
            calendar.hide();
      }
};

Calendar.prototype.bindYear = function() {
      var ys = this.form.yearSelect;
      ys.length = 0;
      for (var i = this.beginYear; i <= this.endYear; i++){
          ys.options[ys.length]=new Option(i+Calendar.language["year"][this.language], i);
      }
};

Calendar.prototype.bindMonth = function() {
      var ms = this.form.monthSelect;
      ms.length = 0;
      for (var i = 0; i < 12; i++){
            ms.options[ms.length]=new Option(Calendar.language["months"][this.language][i], i);
      }
};

Calendar.prototype.goPrevMonth = function(e) {
      if (this.year == this.beginYear && this.month == 0){return;}
      this.month--;
      if (this.month == -1) {
            this.year--;
            this.month = 11;
      }
      this.date = new Date(this.year, this.month, 1);
      this.changeSelect();
      this.bindData();
};

Calendar.prototype.goNextMonth = function(e){
      if(this.year == this.endYear && this.month == 11){return;}
      this.month++;
      if (this.month == 12) {
            this.year++;
            this.month = 0;
      }
      this.date = new Date(this.year, this.month, 1);
      this.changeSelect();
      this.bindData();
};

Calendar.prototype.changeSelect = function() {
      var ys = this.form.yearSelect;
      var ms = this.form.monthSelect;
      for(var i= 0; i < ys.length; i++){
            if(ys.options[i].value == this.date.getFullYear()) {
                  ys[i].selected = true;
                  break;
            }
      }
      for (var i= 0; i < ms.length; i++) {
            if (ms.options[i].value == this.date.getMonth()){
                  ms[i].selected = true;
                  break;
            }
      }
};

Calendar.prototype.update = function (e) {
      this.year  = e.form.yearSelect.options[e.form.yearSelect.selectedIndex].value;
      this.month = e.form.monthSelect.options[e.form.monthSelect.selectedIndex].value;
      this.date = new Date(this.year, this.month, 1);
      this.changeSelect();
      this.bindData();
};

Calendar.prototype.bindData = function () {
      var calendar = this;
      var dateArray = this.getMonthViewDateArray(this.date.getFullYear(), this.date.getMonth());
      var tds = this.getElementsByTagName("td", this.getElementById("__calendarTable", this.iframe.document));
      for(var i = 0; i < tds.length; i++) {
            tds[i].style.backgroundColor = calendar.colors["bg_over"];
            tds[i].onclick = null;
            tds[i].onmouseover = null;
            tds[i].onmouseout = null;
            tds[i].innerHTML = dateArray[i] || "&nbsp;";
            if(i > dateArray.length - 1) continue;
            if(dateArray[i]){
                  tds[i].onclick = function () {
                  if (calendar.dateControl){
                        calendar.dateControl.value = new Date(calendar.date.getFullYear(),
              calendar.date.getMonth(),this.innerHTML).format(calendar.date2StringPattern);
                  }
                  calendar.hide();
            }
      tds[i].onmouseover = function() {this.style.backgroundColor = calendar.colors["bg_out"];}
      tds[i].onmouseout = function() {this.style.backgroundColor = calendar.colors["bg_over"];}
      var today = new Date();
      if(today.getFullYear() == calendar.date.getFullYear()) {
            if(today.getMonth() == calendar.date.getMonth()) {
                  if(today.getDate() == dateArray[i]) {
                        tds[i].style.backgroundColor = calendar.colors["bg_cur_day"];
                        tds[i].onmouseover = function() {this.style.backgroundColor = calendar.colors["bg_out"];}
                        tds[i].onmouseout  = function() {this.style.backgroundColor = calendar.colors["bg_cur_day"];}
                  }
            }
      }
      }//end if
      }//end for
};

Calendar.prototype.getMonthViewDateArray = function(y, m) {
      var dateArray = new Array(42);
      var dayOfFirstDate = new Date(y, m, 1).getDay();
      var dateCountOfMonth = new Date(y, m + 1, 0).getDate();
      for(var i = 0; i < dateCountOfMonth; i++) {
            dateArray[i + dayOfFirstDate] = i + 1;
      }
      return dateArray;
};

Calendar.prototype.show = function (dateControl, popuControl) {
      if(this.panel.style.visibility == "visible") {
            this.panel.style.visibility = "hidden";
      }
      if(!dateControl){
            throw new Error("arguments[0] is necessary!")
      }
      this.dateControl = dateControl;
      popuControl = popuControl || dateControl;

      this.draw();
      this.bindYear();
      this.bindMonth();
      if(dateControl.value.length > 0) {
            this.date  = new Date(dateControl.value.toDate(this.patternDelimiter, this.string2DatePattern));
            this.year  = this.date.getFullYear();
            this.month = this.date.getMonth();
      }
      this.changeSelect();
      this.bindData();

      var xy = this.getAbsPoint(popuControl);
      this.panel.style.left = xy.x + "px";
      this.panel.style.top = (xy.y + dateControl.offsetHeight) + "px";
      this.panel.style.visibility = "visible";
};

Calendar.prototype.hide = function() {
      this.panel.style.visibility = "hidden";
};

Calendar.prototype.getElementById = function(id, object) {
      object = object || document;
      return document.getElementById ? object.getElementById(id) : document.all(id);
};

Calendar.prototype.getElementsByTagName = function(tagName, object) {
      object = object || document;
      return document.getElementsByTagName ? object.getElementsByTagName(tagName) : document.all.tags(tagName);
};

Calendar.prototype.getAbsPoint = function (e) {
      var x = e.offsetLeft;
      var y = e.offsetTop;
      while(e = e.offsetParent) {
            x += e.offsetLeft;
            y += e.offsetTop;
      }
      return {"x": x, "y": y};
};

/**
 * @param               d the delimiter
 * @param               p the pattern of your date
 * @author              martin
 */
Date.prototype.format = function(style) {
      var o = {
            "M+" : this.getMonth() + 1,                                      //month
            "d+" : this.getDate(),                                              //day
            "h+" : this.getHours(),                                             //hour
            "m+" : this.getMinutes(),                                         //minute
            "s+" : this.getSeconds(),                                         //second
            "w+" : "/u65e5/u4e00/u4e8c/u4e09/u56db/u4e94/u516d".charAt(this.getDay()),                                                                                   //week
            "q+" : Math.floor((this.getMonth() + 3) / 3),               //quarter
            "S"  : this.getMilliseconds()                                      //millisecond
 }
      if (/(y+)/.test(style)) {
            style = style.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
      }
      for(var k in o) {
            if(new RegExp("("+ k +")").test(style)) {
                  style = style.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
            }
      }
      return style;
};

/**
 * @param d the delimiter
 * @param p the pattern of your date
 * @version build 2006.12.15
 */
String.prototype.toDate = function(delimiter, pattern) {
      delimiter = delimiter || "-";
      pattern = pattern || "ymd";
      var a = this.split(delimiter);
      var y = parseInt(a[pattern.indexOf("y")], 10);
      //remember to change this next century ;)
      if(y.toString().length <= 2) y += 2000;
      if(isNaN(y)) y = new Date().getFullYear();
      var m = parseInt(a[pattern.indexOf("m")], 10) - 1;
      var d = parseInt(a[pattern.indexOf("d")], 10);
      if(isNaN(d)) d = 1;
      return new Date(y, m, d);
};

document.writeln('<div id="__calendarPanel" style="position:absolute;visibility:hidden;z-      index:9999;background-color:#FFFFFF;border:1px solid              #666666;width:200px;height:216px;">');
document.writeln('<iframe name="__calendarIframe" id="__calendarIframe"       width="100%" height="100%" scrolling="no" frameborder="0" style="margin:0px;"><//iframe>');
var __ci = window.frames['__calendarIframe'];
__ci.document.writeln('<!DOCTYPE html PUBLIC "-W3CDTD XHTML 1.0 TransitionalEN" "http:www.w3.org//TR//xhtml1//DTD//xhtml1-transitional.dtd">');
__ci.document.writeln('<html xmlns="http:www.w3.org//1999//xhtml">');
__ci.document.writeln('<head>');
__ci.document.writeln('<meta http-equiv="Content-Type" content="text//html; charset=utf-8" //>');
__ci.document.writeln('<title>Web Calendar(UTF-8) Written By KimSoft<//title>');
__ci.document.writeln('<style type="text//css">');
__ci.document.writeln('<!--');
__ci.document.writeln('body {font-size:12px;margin:0px;text-align:center;}');
__ci.document.writeln('form {margin:0px;}');
__ci.document.writeln('select {font-size:12px;background-color:#EFEFEF;}');
__ci.document.writeln('table {border:0px solid #CCCCCC;background-color:#FFFFFF}');
__ci.document.writeln('th {font-size:12px;font-weight:normal;background-color:#FFFFFF;}');
__ci.document.writeln('th.theader {font-weight:normal;background-color:#666666;color:#FFFFFF;width:24px;}');
__ci.document.writeln('select.year {width:67px;}');
__ci.document.writeln('select.month {width:62px;}');
__ci.document.writeln('td {font-size:12px;text-align:center;}');
__ci.document.writeln('td.sat {color:#0000FF;background-color:#EFEFEF;}');
__ci.document.writeln('td.sun {color:#FF0000;background-color:#EFEFEF;}');
__ci.document.writeln('td.normal {background-color:#EFEFEF;}');
__ci.document.writeln('input.l {border: 1px solid #CCCCCC;background-color:#EFEFEF;width:20px;height:20px;}');
__ci.document.writeln('input.r {border: 1px solid #CCCCCC;background-color:#EFEFEF;width:20px;height:20px;}');
__ci.document.writeln('input.b {border: 1px solid #CCCCCC;background-color:#EFEFEF;width:100%;height:20px;}');
__ci.document.writeln('-->');
__ci.document.writeln('<//style>');
__ci.document.writeln('<//head>');
__ci.document.writeln('<body>');
__ci.document.writeln('<//body>');
__ci.document.writeln('<//html>');
__ci.document.close();
document.writeln('<//div>');
var calendar = new Calendar();

-------------------------------------------程序调用----------------------------------------

<span style="width:35px"></span>选择日期:
               <input type="text" name="txtStart" size="7" οnclick="new Calendar().show(this);"/><input type="checkbox" name="chkStart" onpropertychange="isSelected(this,document.czform.txtStart)"/>
               至<input type="text" name="txtEnd" size="8" οnclick="new Calendar().show(this);"/><input type="checkbox" name="chkEnd" onpropertychange="isSelected(this,document.czform.txtEnd)"/>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值