<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    小菜毛毛技術分享

    與大家共同成長

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      164 Posts :: 141 Stories :: 94 Comments :: 0 Trackbacks

    二種JavaScript日期控件(日期選擇器)

    • QQ群:Y③WEB開發(DIV+CSS)號碼:16610506 QQ群:Y④WEB開發(JS+AJAX)號碼:16143998
    • QQ群:Y⑤WEB開發(新手)號碼:12777715 MSN群:yaosansi[at]126.com
    • 本站大部分內容從網上收集,收集目的僅供研究、學習。涉及版權或不希望收錄您的文章請您及時與我聯系。
    • 本站IM群,請自行選擇。請各位朋友按照自己喜好加入。加入群后請及時發言,防止被清理。謝謝您的合作!!!
    • QQ群:Y①WEB開發(ASP.NET)號碼:7351660 QQ群:Y②WEB開發(ASP+.NET)號碼:11864905

    控件一:


     


    <HTML>
    <HEAD>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <meta http-equiv="Content-Language" content="zh-cn">
    <TITLE></TITLE>
    <script language="javascript" src="http://www.yaosansi.com/upload/month_0604/52006426163027.js" ></script>
    </head>
    <BODY >
    <script >
    var oCalendarEn=new PopupCalendar("oCalendarEn");    //初始化控件時,請給出實例名稱如:oCalendarEn
    oCalendarEn.Init();

    var oCalendarChs=new PopupCalendar("oCalendarChs");    //初始化控件時,請給出實例名稱:oCalendarChs
    oCalendarChs.weekDaySting=new Array("","","","","","","");
    oCalendarChs.monthSting
    =new Array("一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月");
    oCalendarChs.oBtnTodayTitle
    ="今天";
    oCalendarChs.oBtnCancelTitle
    ="取消";
    oCalendarChs.Init();
    </script>
    <br><br><br><br>
       
    <input readonly type="text" name="dd" id="aa" onclick="getDateString(this,oCalendarEn)" value="English Version">
    <br><br><br><br>
       
    <input readonly type="text" name="dd" id="aa" onclick="getDateString(this,oCalendarChs)" value="中文界面版">                                   
    </BODY>
    </HTML>

    點擊下載

    ------------------------------------------------------------------------------------------------------------------------------------------------------

    控件二:



     


    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
    <meta http-equiv="Content-Language" content="zh-cn">
    <style>
    <!--
    td, input    
    { font-family: Tahoma; font-size: 8pt; color: #000080 }
    -->
    </style>
    </head>
    <!--第1部分完成對一個文本框和一個隱藏的div層的生成,已經相關的CSS等等-->
    <!--↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 第1部分 ↓↓↓↓↓↓↓↓↓↓↓↓↓↓-->
    <!--在頁面上顯示一個文本輸入框,放置一個onclick事件-->
    <body bgcolor="#D6D3CE">
    <div align="center">
      
    <center>
      
    <table width="248" border="0">
        
    <tr>
    <!--在這里,fPopCalendar(regdate,regdate)的兩個參數實際上把整個regdate
    (文本框)對象帶過去了
    -->
          
    <td nowrap width="599">選擇時間:<input class="input" onClick="fPopCalendar(regdate,regdate);return false" type="text" name="regdate" size="12">
    </td>
        
    </tr>
      
    </table>
      
    </center>
    </div>
    <script>
    //定義一些變量
    var gdCtrl = new Object();
    var goSelectTag = new Array();
    var gcGray   = "#808080";
    var gcToggle = "#FB8664";
    var gcBG = "#e5e6ec";
    var previousObject = null;
    var gdCurDate = new Date();
    var giYear = gdCurDate.getFullYear();
    var giMonth = gdCurDate.getMonth()+1;
    var giDay = gdCurDate.getDate();
    var gMonths = new Array("一月","二月","三月","四月","五月","六月","七月","八月"
    ,
    "九月","十月","十一月","十二月");
    //顯示一個隱藏的層,放置日期的選擇框。
    with (document) {
    write(
    "<Div id=VicPopCal style=POSITION:absolute;VISIBILITY:hidden;border:2px ridge;z-index:100;>");
    write(
    "<table border=0 bgcolor=#cccccc>");
    write(
    "<TR>");
    write(
    "<td valign=middle align=center><input type=button name=PrevMonth value='<' style=height:20;width:20;FONT:bold onClick=fPrevMonth()>");
    write(
    " <Select name=tbSelYear onChange=fUpdateCal(tbSelYear.value, tbSelMonth.value) Victor=Won>");
    for(i=1950;i<2015;i++)
        write(
    "<OPTION value="+i+">"+i+" 年</OPTION>");
    write(
    "</Select>");
    write(
    " <select name=tbSelMonth onChange=fUpdateCal(tbSelYear.value, tbSelMonth.value) Victor=Won>");
    for (i=0; i<12; i++)
        write(
    "<option value="+(i+1)+">"+gMonths[i]+"</option>");
    write(
    "</Select>");
    write(
    "<input type=button name=PrevMonth value='>' style=height:20;width:20;FONT:bold onclick=fNextMonth()>");
    write(
    "</td>");
    write(
    "</TR><TR>");
    write(
    "<td align=center>");
    write(
    "<DIV style=background-color:teal><table width=100% border=0>");
    //fDrawCal()函數完成日期的顯示。fDrawCal()函數有4個參數,第1個表示顯示的年份,第2個參數表示顯示的月份,第3個參數表示
    //
    顯示的格子的高度,最后一個參數應該是字體寬度,但是似乎不起作用。
    fDrawCal(giYear, giMonth, 2012);
    function fDrawCal(iYear, iMonth, iCellHeight, sDateTextSize) {
    //建立WeekDay數組。
      var WeekDay = new Array("","","","","","","");
    //建立styleTD,就是每一個TD的style。
      var styleTD = " bgcolor="+gcBG+" bordercolor="+gcBG+" valign=middle align=center height="+iCellHeight+" style=font:bold arial "+sDateTextSize+";";
      
    with (document) {
        write(
    "<tr>");
    //這個for完成星期的顯示。
        for(i=0; i<7; i++){
            write(
    "<td "+styleTD+"color:maroon >"+ WeekDay[i] + "</td>");
        }

        write(
    "</tr>");
    //在這里,每個格子(6行7列)的顯示內容暫時都是空的,要由后面的fUpdateCal()函數完成。
          for (w = 1; w < 7; w++{
            write(
    "<tr>");
            
    for (d = 0; d < 7; d++{
                write(
    "<td id=calCell "+styleTD+"cursor:hand; onMouseOver=this.bgColor=gcToggle onMouseOut=this.bgColor=gcBG onclick=fSetSelected(this)>");
                write(
    "<font id=cellText Victor=Hcy_Flag> </font>");            
                write(
    "</td>")
            }

            write(
    "</tr>");
        }

      }

    }

    write(
    "</table></DIV>");
    write(
    "</td>");
    write(
    "</TR><TR><TD align=center>");
    write(
    "<TABLE width=100%><TR><TD align=center>");
    write(
    "<B style=cursor:hand onclick=fSetDate(0,0,0) onMouseOver=this.style.color=gcToggle onMouseOut=this.style.color=0>清空</B>");
    write(
    "</td><td algin=center>");
    write(
    "<B style=cursor:hand onclick=fSetDate(giYear,giMonth,giDay) onMouseOver=this.style.color=gcToggle onMouseOut=this.style.color=0>今天: "+giYear+"-"+giMonth+"-"+giDay+"</B>");
    write(
    "</td></tr></table>");
    write(
    "</TD></TR>");
    write(
    "</TABLE></Div>");
    }

    //↑↑↑↑↑↑↑↑↑↑↑↑↑↑ 第1部分 ↑↑↑↑↑↑↑↑↑↑↑↑↑↑
    //
    第2部分的內容是4個輔助日期顯示的函數。
    //
    ↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 第2部分 ↓↓↓↓↓↓↓↓↓↓↓↓↓↓
    //
    fPopCalendar()函數完成日期div的顯示和隱藏操作。fPopCalendar()函數有3個參數,第1個參數和第2個參數表示兩個控件對象。
    function fPopCalendar(popCtrl, dateCtrl){
    //因為有后面的previousObject = popCtrl附值操作,所以這里可以理解成是再次點擊文本框時修改調用HiddenDiv()函數取消顯示。
      if (popCtrl == previousObject){
              
    if (VicPopCal.style.visibility == "visible"){
              HiddenDiv();
              
    return true;
          }

      }

      previousObject 
    = popCtrl;
      gdCtrl 
    = dateCtrl;
      fSetYearMon(giYear, giMonth);
    //調用fGetXY()函數獲取控件的坐標。 
      var point = fGetXY(popCtrl);
      
    with (VicPopCal.style) {
    //給定顯示層的絕對位置。
        left = point.x;
        top  
    = point.y+popCtrl.offsetHeight;
        width 
    = VicPopCal.offsetWidth;
        height 
    = VicPopCal.offsetHeight;
        
    //fToggleTags(point);     
        visibility = "visible";
      }

    }

    //HiddenDiv()函數取消日期顯示框div層的顯示。
    function HiddenDiv()
    {
        
    var i;
      VicPopCal.style.visibility 
    = "hidden";
    }

    //fUpdateCal()函數完成日期文字在頁面div中的顯示,fUpdateCal()有兩個參數,第1個參數表示年份,第2個參數表示月份。
    function fUpdateCal(iYear, iMonth) {
    //fBuildCal()函數獲取給定日期所有需要顯示的日期內容。
      myMonth = fBuildCal(iYear, iMonth);
      
    var i = 0;
      
    for (w = 0; w < 6; w++)
        
    for (d = 0; d < 7; d++)
            
    with (cellText[(7*w)+d]) {
    //Victor作為一個參數,用作判斷同為負值的一些日期月份的變化。
                Victor = i++;
    //這個if完成對日期的所有顯示,同時完成所有的對日期顏色的操作。
                if (myMonth[w+1][d]<0{
                    color 
    = gcGray;
                    innerText 
    = -myMonth[w+1][d];
                }
    else{
                    color 
    = ((d==0)||(d==6))?"red":"black";
                    innerText 
    = myMonth[w+1][d];
                }

            }

    }

    //fBuildCal()函數獲取給定日期所有需要顯示的日期內容。fBuildCal()函數有兩個參數,第1個表示年份,第2個表示月份。
    function fBuildCal(iYear, iMonth) {
    //建立aMonth[1]到aMonth[6]六個空數組,最后的new Array(i)中的“i”不知道有什么作用,似乎可以去掉。
      var aMonth=new Array();
      
    for(i=1;i<7;i++)
          aMonth[i]
    =new Array(i);
    //Date對象的3個參數是必選的,表示給定的時間坐標,其中月份值比較特殊,6月份是用數字5表示的,1月份是用數字0表
    //
    示的,所以要減去1。iDayOfFirst表示給定時間軸日期的星期值,iDaysInMonth表示所給年月的總的日期數。iOffsetLast
    //
    表示在頁面第一個格子中需要顯示的上個月的日期值(在這里iYear,iMonth都是值的現在的時間)。
      var dCalDate=new Date(iYear, iMonth-11);
      
    var iDayOfFirst=dCalDate.getDay();
      
    var iDaysInMonth=new Date(iYear, iMonth, 0).getDate();
      
    var iOffsetLast=new Date(iYear, iMonth-10).getDate()-iDayOfFirst+1;
      
    var iDate = 1;
      
    var iNext = 1;
    //這個for完成第一行的顯示,作者讓剛開始的幾天用負數表示,便于以后的頁面顯示,很好的方法。
      for (d = 0; d < 7; d++)
        aMonth[
    1][d] = (d<iDayOfFirst)?-(iOffsetLast+d):iDate++;
    //這個for完成2-6行的顯示,依舊用負數表示下個月的日期。
      for (w = 2; w < 7; w++)
          
    for (d = 0; d < 7; d++)
            aMonth[w][d] 
    = (iDate<=iDaysInMonth)?iDate++:-(iNext++);
      
    return aMonth;
    }

    //↑↑↑↑↑↑↑↑↑↑↑↑↑↑ 第2部分 ↑↑↑↑↑↑↑↑↑↑↑↑↑↑

    //事件函數。
    //
    ↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 第3部分 ↓↓↓↓↓↓↓↓↓↓↓↓↓↓
    //
    fPrevMonth()函數顯示上個月的日期。
    function fPrevMonth(){
    //tbSelMonth.value表示select中選中的月份值,tbSelYear.value表示select中選中的年份值。
      var iMon = tbSelMonth.value;
      
    var iYear = tbSelYear.value;
      
    if (--iMon<1{
          iMon 
    = 12;
          iYear
    --;
      }

    //調用fSetYearMon函數顯示最新的月份內容。
      fSetYearMon(iYear, iMon);
    }

    //fPrevMonth()函數顯示下個月的日期。
    function fNextMonth(){
    //tbSelMonth.value表示select中選中的月份值,tbSelYear.value表示select中選中的年份值。
      var iMon = tbSelMonth.value;
      
    var iYear = tbSelYear.value;
      
    if (++iMon>12{
          iMon 
    = 1;
          iYear
    ++;
      }

    //調用fSetYearMon函數顯示最新的月份內容。
      fSetYearMon(iYear, iMon);
    }

    //fSetYearMon()函數可以按照給定的時間,在頁面中進行日期的顯示。fSetYearMon()函數有兩個參數,第1個參數表示
    //
    給定的年份,第2個參數表示給定的月份。
    function fSetYearMon(iYear, iMon){
    //因為6月份是用數字5表示,所以-1,選中。
      tbSelMonth.options[iMon-1].selected = true;
    //年份的選擇有點復雜,但這似乎也是唯一的辦法。
      for (i = 0; i < tbSelYear.length; i++)
        
    if (tbSelYear.options[i].value == iYear)
            tbSelYear.options[i].selected 
    = true;
    //完成了上面兩個select的顯示之后調用fUpdateCal()函數完成頁面日期的顯示。
      fUpdateCal(iYear, iMon);
    }

    //fSetDate()函數實現div層中的“清空”和“今天”的操作。
    function fSetDate(iYear, iMonth, iDay){
      VicPopCal.style.visibility 
    = "hidden";
    //fSetDate(0,0,0)實現清空文本框。
      if ((iYear == 0&& (iMonth == 0&& (iDay == 0)){
          gdCtrl.value 
    = "";
      }
    else{
          iMonth 
    = iMonth + 100 + "";
          iMonth 
    = iMonth.substring(1);
          iDay   
    = iDay + 100 + "";
          iDay   
    = iDay.substring(1);
          
    if(gdCtrl.tagName == "INPUT"){
                gdCtrl.value 
    = iYear+"-"+iMonth+"-"+iDay;
          }
    else{
                gdCtrl.innerText 
    = iYear+"-"+iMonth+"-"+iDay;
          }

      }

    }

    //fSetSelected()函數實現點擊日期時的JS操作。
    function fSetSelected(aCell){
      
    var iOffset = 0;
    //獲取select中選中的年月份。
      var iYear = parseInt(tbSelYear.value);
      
    var iMonth = parseInt(tbSelMonth.value);
    //每一個顯示日期的格子都有同一個ID“cellText”,這里用children方法可以獲取操作的對象,srcElement也許會更
    //
    清晰明了一些。
      with (aCell.children["cellText"]){
          
    var iDay = parseInt(innerText);
    //Victor參數的作用就在這里,如果是上個月的日期,則月份-1,如果是下個月的日期,則月份+1。
          if (color==gcGray)
            iOffset 
    = (Victor<10)?-1:1;
        iMonth 
    += iOffset;
    //這個if完成隔年的情況下的操作。
        if (iMonth<1{
            iYear
    --;
            iMonth 
    = 12;
        }
    else if (iMonth>12){
            iYear
    ++;
            iMonth 
    = 1;
        }

      }

    //調用fSetDate()完成日期的最后顯示。
      fSetDate(iYear, iMonth, iDay);
    }

    //↑↑↑↑↑↑↑↑↑↑↑↑↑↑ 第3部分 ↑↑↑↑↑↑↑↑↑↑↑↑↑↑

    //兩個小的工具函數,獲取坐標。
    //
    ↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 第4部分 ↓↓↓↓↓↓↓↓↓↓↓↓↓↓
    //
    Point()函數重新定位坐標。
    function Point(iX, iY){
        
    this.x = iX;
        
    this.y = iY;
    }

    //fGetXY()函數獲取某一給定對象的大小坐標
    function fGetXY(aTag){
      
    var oTmp = aTag;
      
    var pt = new Point(0,0);
      
    do {
          pt.x 
    += oTmp.offsetLeft;
          pt.y 
    += oTmp.offsetTop;
    //offsetParent表示在HTML中的上一個標簽的對象合集。
          oTmp = oTmp.offsetParent;
      }
     while(oTmp.tagName!="BODY");
      
    return pt;
    }

    //↑↑↑↑↑↑↑↑↑↑↑↑↑↑ 第4部分 ↑↑↑↑↑↑↑↑↑↑↑↑↑↑
    </script>
    </body>
    </html>

    posted on 2010-02-24 16:56 小菜毛毛 閱讀(887) 評論(0)  編輯  收藏 所屬分類: HTML+div+css實踐
    主站蜘蛛池模板: 成全视频在线观看免费| 亚洲 小说区 图片区 都市| 亚洲精品自产拍在线观看| 69式国产真人免费视频 | 日本亚洲欧洲免费天堂午夜看片女人员| 亚洲熟妇无码av另类vr影视| 女人张腿给男人桶视频免费版| 免费a级毛片无码a∨免费软件| 青青久久精品国产免费看| 亚洲自偷自偷在线制服 | 亚洲砖码砖专无区2023 | 无码国产精品一区二区免费虚拟VR | a国产成人免费视频| 瑟瑟网站免费网站入口| 亚洲色www永久网站| 亚洲一区二区三区免费观看| 亚洲AV无码欧洲AV无码网站| 亚洲伊人久久精品影院| 亚洲熟伦熟女新五十路熟妇| 又粗又硬又大又爽免费视频播放| 成年18网站免费视频网站| 国产大片线上免费观看| 51精品视频免费国产专区| 一级毛片全部免费播放| 日本免费一区二区久久人人澡| 二个人看的www免费视频| jizz免费观看| 国产免费久久精品丫丫| 国产99久久久国产精免费| 免费在线观看一区| 一个人看的www免费高清| 亚洲成人黄色网址| 亚洲黄色在线视频| 亚洲欧洲日产韩国在线| 亚洲欧洲国产成人精品| 亚洲免费视频网址| 亚洲色偷偷综合亚洲av78| 亚洲精品乱码久久久久蜜桃 | 黄页网站在线视频免费| 女人裸身j部免费视频无遮挡| 黄色a级片免费看|