免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3194 | 回复: 1
打印 上一主题 下一主题

WebCalendar.js兼容ie和火狐js日历插件 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-12 22:24 |只看该作者 |倒序浏览
WebCalendar.js兼容ie和火狐js日历插件
  1. //调用<input type=text onclick="SelectDate(this,'yyyy-MM-dd');">
  2. //<script language="javascript" src=“WebCalendar.js” type="text/javascript" charset="utf8"></script>


  3. var cal;
  4. var isFocus=false; //是否为焦点
  5. //自加
  6. var objdate

  7. //选择日期
  8. function SelectDate(obj,strFormat)
  9. {
  10.     //自加
  11.     objdate = obj;

  12.     var date = new Date();
  13.     var by = date.getFullYear()-50;  //最小值 → 50 年前
  14.     var ey = date.getFullYear()+50;  //最大值 → 50 年后
  15.     cal = (cal==null) ? new Calendar(by, ey, 0) : cal;    //初始化英文版,0 为中文版
  16.     cal.dateFormatStyle = strFormat;
  17.     cal.show(obj);
  18. }
  19. /**//**//**//**
  20. * 返回日期
  21. * @param d the delimiter
  22. * @param p the pattern of your date
  23. * 根据用户指定的 style 来确定;
  24. */
  25. //String.prototype.toDate = function(x, p) {
  26. String.prototype.toDate = function(style) {
  27.     var y = this.substring(style.indexOf('y'),style.lastIndexOf('y')+1);//年
  28.     var m = this.substring(style.indexOf('M'),style.lastIndexOf('M')+1);//月
  29.     var d = this.substring(style.indexOf('d'),style.lastIndexOf('d')+1);//日
  30.     if(isNaN(y)) y = new Date().getFullYear();
  31.     if(isNaN(m)) m = new Date().getMonth();
  32.     if(isNaN(d)) d = new Date().getDate();
  33.     var dt ;
  34.     eval ("dt = new Date('"+ y+"', '"+(m-1)+"','"+ d +"')");
  35.     return dt;
  36. }

  37. /**//**//**//**
  38. * 格式化日期
  39. * @param   d the delimiter
  40. * @param   p the pattern of your date
  41. * @author  meizz
  42. */
  43. Date.prototype.format = function(style) {
  44.     var o = {
  45.         "M+" : this.getMonth() + 1, //month
  46.         "d+" : this.getDate(),      //day
  47.         "h+" : this.getHours(),     //hour
  48.         "m+" : this.getMinutes(),   //minute
  49.         "s+" : this.getSeconds(),   //second
  50.         "w+" : "天一二三四五六".charAt(this.getDay()),   //week
  51.         "q+" : Math.floor((this.getMonth() + 3) / 3),  //quarter
  52.         "S"  : this.getMilliseconds() //millisecond
  53.     }
  54.     if(/(y+)/.test(style)) {
  55.         style = style.replace(RegExp.$1,
  56.             (this.getFullYear() + "").substr(4 - RegExp.$1.length));
  57.     }
  58.     for(var k in o){
  59.         if(new RegExp("("+ k +")").test(style)){
  60.             style = style.replace(RegExp.$1,
  61.                 RegExp.$1.length == 1 ? o[k] :
  62.                 ("00" + o[k]).substr(("" + o[k]).length));
  63.         }
  64.     }
  65.     return style;
  66. };

  67. /**//**//**//**
  68. * 日历类
  69. * @param   beginYear 1990
  70. * @param   endYear   2010
  71. * @param   lang      0(中文)|1(英语) 可自由扩充
  72. * @param   dateFormatStyle  "yyyy-MM-dd";
  73. * @version 2006-04-01
  74. * @author  KimSoft (jinqinghua [at] gmail.com)
  75. * @update
  76. */
  77. function Calendar(beginYear, endYear, lang, dateFormatStyle) {
  78.     var date = new Date();
  79.     this.beginYear = date.getFullYear()-50;  //最小值 → 50 年前
  80.     this.endYear = date.getFullYear()+50;  //最大值 → 50 年后
  81.     this.lang = 0;            //0(中文) | 1(英文)
  82.     this.dateFormatStyle = "yyyy-MM-dd";

  83.     if (beginYear != null && endYear != null){
  84.         this.beginYear = beginYear;
  85.         this.endYear = endYear;
  86.     }
  87.     if (lang != null){
  88.         this.lang = lang
  89.     }

  90.     if (dateFormatStyle != null){
  91.         this.dateFormatStyle = dateFormatStyle
  92.     }

  93.     this.dateControl = null;
  94.     this.panel = this.getElementById("calendarPanel");
  95.     this.container = this.getElementById("ContainerPanel");
  96.     this.form  = null;

  97.     this.date = new Date();
  98.     this.year = this.date.getFullYear();
  99.     this.month = this.date.getMonth();


  100.     this.colors = {
  101.         "cur_word"      : "#FFFFFF",  //当日日期文字颜色
  102.         "cur_bg"        : "#00FF00",  //当日日期单元格背影色
  103.         "sel_bg"        : "#FFCCCC",  //已被选择的日期单元格背影色 2006-12-03 寒羽枫添加
  104.         "sun_word"      : "#FF0000",  //星期天文字颜色
  105.         "sat_word"      : "#0000FF",  //星期六文字颜色
  106.         "td_word_light" : "#333333",  //单元格文字颜色
  107.         "td_word_dark"  : "#CCCCCC",  //单元格文字暗色
  108.         "td_bg_out"     : "#EFEFEF",  //单元格背影色
  109.         "td_bg_over"    : "#FFCC00",  //单元格背影色
  110.         "tr_word"       : "#FFFFFF",  //日历头文字颜色
  111.         "tr_bg"         : "#666666",  //日历头背影色
  112.         "input_border"  : "#CCCCCC",  //input控件的边框颜色
  113.         "input_bg"      : "#EFEFEF"   //input控件的背影色
  114.     }

  115.     this.draw();
  116.     this.bindYear();
  117.     this.bindMonth();
  118.     this.changeSelect();
  119.     this.bindData();
  120. }

  121. /**//**//**//**
  122. * 日历类属性(语言包,可自由扩展)
  123. */
  124. Calendar.language = {
  125.     "year"   : [[""], [""]],
  126.     "months" : [["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],
  127.      ["JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"]
  128.     ],
  129.     "weeks"  : [["日","一","二","三","四","五","六"],
  130.     ["SUN","MON","TUR","WED","THU","FRI","SAT"]
  131.     ],
  132.     "clear"  : [["清空"], ["CLS"]],
  133.     "today"  : [["今天"], ["TODAY"]],
  134.     "close"  : [["关闭"], ["CLOSE"]]
  135. }

  136. Calendar.prototype.draw = function() {
  137.     calendar = this;

  138.     var mvAry = [];
  139.     mvAry[mvAry.length]  = '  <div name="calendarForm" style="margin: 0px;">';
  140.     mvAry[mvAry.length]  = '    <table width="100%" border="0" cellpadding="0" cellspacing="1">';
  141.      mvAry[mvAry.length]  = '      <tr>';
  142.     mvAry[mvAry.length]  = '        <th align="left" width="1%"><input style="border: 1px solid ' + calendar.colors["input_border"] + ';background-color:' + calendar.colors["input_bg"] + ';width:16px;height:20px;" name="prevMonth" type="button" id="prevMonth" value="&lt;" /></th>';
  143.      mvAry[mvAry.length]  = '        <th align="center" width="98%" nowrap="nowrap"><select name="calendarYear" id="calendarYear" style="font-size:12px;"></select><select name="calendarMonth" id="calendarMonth" style="font-size:12px;"></select></th>';
  144.      mvAry[mvAry.length]  = '        <th align="right" width="1%"><input style="border: 1px solid ' + calendar.colors["input_border"] + ';background-color:' + calendar.colors["input_bg"] + ';width:16px;height:20px;" name="nextMonth" type="button" id="nextMonth" value="&gt;" /></th>';
  145.      mvAry[mvAry.length]  = '      </tr>';
  146.     mvAry[mvAry.length]  = '    </table>';
  147.     mvAry[mvAry.length]  = '    <table id="calendarTable" width="100%" style="border:0px solid #CCCCCC;background-color:#FFFFFF;font-size:9pt" border="0" cellpadding="2" cellspacing="1">';
  148.      mvAry[mvAry.length]  = '      <tr>';
  149.     for(var i = 0; i < 7; i++) {
  150.         mvAry[mvAry.length]  = '      <th style="font-weight:normal;background-color:' + calendar.colors["tr_bg"] + ';color:' + calendar.colors["tr_word"] + ';">' + Calendar.language["weeks"][this.lang][i] + '</th>';
  151.      }
  152.     mvAry[mvAry.length]  = '      </tr>';
  153.     for(var i = 0; i < 6;i++){
  154.         mvAry[mvAry.length]  = '    <tr align="center">';
  155.         for(var j = 0; j < 7; j++) {
  156.             if (j == 0){
  157.                 mvAry[mvAry.length]  = '  <td style="cursor:default;color:' + calendar.colors["sun_word"] + ';"></td>';
  158.              } else if(j == 6) {
  159.                 mvAry[mvAry.length]  = '  <td style="cursor:default;color:' + calendar.colors["sat_word"] + ';"></td>';
  160.              } else {
  161.                 mvAry[mvAry.length]  = '  <td style="cursor:default;"></td>';
  162.             }
  163.         }
  164.         mvAry[mvAry.length]  = '    </tr>';
  165.     }
  166.     mvAry[mvAry.length]  = '      <tr style="background-color:' + calendar.colors["input_bg"] + ';">';
  167.      mvAry[mvAry.length]  = '        <th colspan="2"><input name="calendarClear" type="button" id="calendarClear" value="' + Calendar.language["clear"][this.lang] + '" style="border: 1px solid ' + calendar.colors["input_border"] + ';background-color:' + calendar.colors["input_bg"] + ';width:100%;height:18px;font-size:9pt;"/></th>';
  168.      mvAry[mvAry.length]  = '        <th colspan="3"><input name="calendarToday" type="button" id="calendarToday" value="' + Calendar.language["today"][this.lang] + '" style="border: 1px solid ' + calendar.colors["input_border"] + ';background-color:' + calendar.colors["input_bg"] + ';width:100%;height:18px;font-size:9pt;"/></th>';
  169.      mvAry[mvAry.length]  = '        <th colspan="2"><input name="calendarClose" type="button" id="calendarClose" value="' + Calendar.language["close"][this.lang] + '" style="border: 1px solid ' + calendar.colors["input_border"] + ';background-color:' + calendar.colors["input_bg"] + ';width:100%;height:18px;font-size:9pt;"/></th>';
  170.      mvAry[mvAry.length]  = '      </tr>';
  171.     mvAry[mvAry.length]  = '    </table>';
  172.     mvAry[mvAry.length]  = '  </div>';
  173.     this.panel.innerHTML = mvAry.join("");

  174.     /**//******** 以下代码由寒羽枫 2006-12-01 添加 **********/
  175.     var obj = this.getElementById("prevMonth");
  176.     obj.onclick = function () {
  177.         calendar.goPrevMonth(calendar);
  178.     }
  179.     obj.onblur = function () {
  180.         calendar.onblur();
  181.     }
  182.     this.prevMonth= obj;

  183.     obj = this.getElementById("nextMonth");
  184.     obj.onclick = function () {
  185.         calendar.goNextMonth(calendar);
  186.     }
  187.     obj.onblur = function () {
  188.         calendar.onblur();
  189.     }
  190.     this.nextMonth= obj;



  191.     obj = this.getElementById("calendarClear");
  192.     obj.onclick = function () {
  193.         calendar.dateControl.value = "";
  194.         calendar.hide();
  195.     }
  196.     this.calendarClear = obj;

  197.     obj = this.getElementById("calendarClose");
  198.     obj.onclick = function () {
  199.         calendar.hide();
  200.     }
  201.     this.calendarClose = obj;

  202.     obj = this.getElementById("calendarYear");
  203.     obj.onchange = function () {
  204.         calendar.update(calendar);
  205.     }
  206.     obj.onblur = function () {
  207.         calendar.onblur();
  208.     }
  209.     this.calendarYear = obj;

  210.     obj = this.getElementById("calendarMonth");
  211.     with(obj)
  212.     {
  213.         onchange = function () {
  214.             calendar.update(calendar);
  215.         }
  216.         onblur = function () {
  217.             calendar.onblur();
  218.         }
  219.         }
  220.     this.calendarMonth = obj;

  221.     obj = this.getElementById("calendarToday");
  222.     obj.onclick = function () {
  223.         var today = new Date();
  224.         calendar.date = today;
  225.         calendar.year = today.getFullYear();
  226.         calendar.month = today.getMonth();
  227.         calendar.changeSelect();
  228.         calendar.bindData();
  229.         calendar.dateControl.value = today.format(calendar.dateFormatStyle);
  230.         calendar.hide();
  231.     }
  232.     this.calendarToday = obj;
  233. }
复制代码
//年份下拉框绑定数据
  1. Calendar.prototype.bindYear = function() {
  2.     var cy = this.calendarYear;
  3.     cy.length = 0;
  4.     for (var i = this.beginYear; i <= this.endYear; i++){
  5.         cy.options[cy.length] = new Option(i + Calendar.language["year"][this.lang], i);
  6.      }
  7. }
复制代码
//月份下拉框绑定数据
  1. Calendar.prototype.bindMonth = function() {
  2.     var cm = this.calendarMonth;
  3.     cm.length = 0;
  4.     for (var i = 0; i < 12; i++){
  5.         cm.options[cm.length] = new Option(Calendar.language["months"][this.lang][i], i);
  6.      }
  7. }
复制代码
//向前一月
  1. Calendar.prototype.goPrevMonth = function(e){
  2.     if (this.year == this.beginYear && this.month == 0){
  3.         return;
  4.     }
  5.     this.month--;
  6.     if (this.month == -1) {
  7.         this.year--;
  8.         this.month = 11;
  9.     }
  10.     this.date = new Date(this.year, this.month, 1);
  11.     this.changeSelect();
  12.     this.bindData();
  13. }
复制代码
//向后一月
  1. Calendar.prototype.goNextMonth = function(e){
  2.     if (this.year == this.endYear && this.month == 11){
  3.         return;
  4.     }
  5.     this.month++;
  6.     if (this.month == 12) {
  7.         this.year++;
  8.         this.month = 0;
  9.     }
  10.     this.date = new Date(this.year, this.month, 1);
  11.     this.changeSelect();
  12.     this.bindData();
  13. }
复制代码
//改变SELECT选中状态[code]Calendar.prototype.changeSelect = function() {
    var cy = this.calendarYear;
    var cm = this.calendarMonth;
    for (var i= 0; i < cy.length; i++){
        if (cy.options.value == this.date.getFullYear()){
            cy.selected = true;
            break;
        }
    }
    for (var i= 0; i < cm.length; i++){
        if (cm.options.value == this.date.getMonth()){
            cm.selected = true;
            break;
        }
    }
} [/code

论坛徽章:
0
2 [报告]
发表于 2011-12-24 20:04 |只看该作者
谢谢分享  希望于楼主多多交流
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP