js日曆

  1 <html>
  2     <head>
  3         <title>日曆表格</title>
  4         <style type="text/css">
  5             .DateTime {
  6                 width: 99%;
  7                 margin-top: 4px;
  8             }
  9             .dateTitle {
 10                 text-align: center;
 11             }
 12             ul li {
 13                 list-style: none;
 14                 float: left;
 15                 width: 14.29%;
 16                 height: 20px;
 17                 border: 1px solid #e6e6e6;
 18                 text-align: center;
 19             }
 20             ul {
 21                 width: 104%;
 22                 text-align: center;
 23                 margin-left: -28px;
 24             }
 25             h2 {
 26                 text-align: center;
 27             }
 28             h1 {
 29                 text-align: center;
 30             }
 31             .wek {
 32                 background-color: #1e1e1e;
 33                 color: #ffffff;
 34             }
 35             .h2title {
 36                 text-align: center;
 37                 height: 50px;
 38                 width: 99%;
 39             }
 40         </style>
 41     </head>
 42     <body>
 43         <div class="DateTime">
 44         </div>
 45     </body>
 46 </html>
 47 @section scripts
 48 {
 49     <script src="~/Scripts/jquery-1.10.2.min.js"></script>
 50     <script>
 51         $(function() {
 52             var nowDate = new Date();
 53             var year = nowDate.getFullYear(); //
 54             var month = nowDate.getMonth() + 1; //
 55             //console.log(month);
 56             var day = nowDate.getDate(); //
 57             var wek = nowDate.getDay(); //
 58             var html = "<h1 class=\" dateTitle\">日曆Title</h1>";
 59             for (var y = year; y < (year + 10); y++) {
 60                 html += "<ul>";
 61                 var YearType = IsRYear(y); //判斷年份類型(閏年/平年)(true/false)
 62                 if (y == year) { //當年份等於當前年份時,循環的月份爲當前月開始,不然自動從1月份開始循環
 63                     for (var m = month; m <= 12; m++) {
 64                         html += "</br><li class=\"h2title\"><h2>" + y + "" + (m) + "月</h2></li></br>";
 65                         html += "<li class=\"wek\">週日</li><li class=\"wek\">週一</li><li class=\"wek\">週二</li><li class=\"wek\">週三</li><li class=\"wek\">週四</li><li class=\"wek\">週五</li><li class=\"wek\">週六</li>";
 66                         if (month > 12) {
 67                             break;
 68                         } else {
 69                             //console.log(y, m, MHasDay(YearType, m)); //調用方法打印日曆
 70                             var GetDate = new Date(y, m-1, 1);
 71                             var dateDay = GetDate.getDay();
 72                             console.log(GetDate,dateDay);
 73                             if (GetDate.getDay() != 0) {
 74                                 for (var bwek = 0; bwek < GetDate.getDay() ; bwek++) {
 75                                     html += "<li>前</li>";
 76                                 }
 77                             }
 78                             var Days = MHasDay(YearType, m); //獲取月天數
 79                             //console.log(m, Days);
 80                             for (var md = 1; md <= Days; md++) {
 81                                 html += "<li>" + md + "</li>";
 82                                 if (md == Days) {
 83                                     var ldate = new Date(y, m, md);
 84                                     var ld = ldate.getDay();
 85                                     for (ld ; ld < 7; ld++) {
 86                                         html += "<li>後</li>";
 87                                     }
 88                                 }
 89                             }
 90                         }
 91                     }
 92                 } else {
 93                     for (var m = 1; m <= 12; m++) {
 94                         html += "<li class=\"h2title\"><h2>" + y + "" + (m) + "月</h2></li>";
 95                         html += "<li class=\"wek\">週日</li><li class=\"wek\">週一</li><li class=\"wek\">週二</li><li class=\"wek\">週三</li><li class=\"wek\">週四</li><li class=\"wek\">週五</li><li class=\"wek\">週六</li>";
 96                         //console.log(y, m, MHasDay(YearType, m));
 97                         if (month > 12) {
 98                             break;
 99                         } else {
100                             //console.log(y, m, MHasDay(YearType, m)); //調用方法打印日曆
101                             var GetDate = new Date(y, m, 1);
102                             //console.log(GetDate.getDay());
103                             if (GetDate.getDay() != 0) {
104                                 for (var bwek = 0; bwek < GetDate.getDay() ; bwek++) {
105                                     html += "<li>   </li>";
106                                 }
107                             }
108                             var Days = MHasDay(YearType, m); //獲取月天數
109                             for (var md = 1; md <= Days; md++) {
110                                 html += "<li>" + md + "</li>";
111                                 if (md == Days) {
112                                     var LDate = new Date(y, m, Days);
113                                     for (var ld = LDate.getDay() ; ld < 7; ld++) {
114                                         html += "<li>   </li>";
115                                     }
116                                 }
117                             }
118                         }
119                     }
120                 }
121                 html += "</ul>";
122             }
123             $('.DateTime').append(html);
124 
125         });
126 
127 //判斷是否爲閏年
128         function IsRYear(year) {
129             if (year % 4 == 0) {
130                 return true;
131             } else {
132                 return false;
133             }
134         }
135 
136 //判斷每個月有幾天
137         function MHasDay(yearType, month) {
138             var monthday = null;
139             if (yearType == true) {
140                 //閏年1月31天,2月29天,3月31天,4月30天,5月31天,6月30天,7月31天,8月31天,9月30天,10月31天,11月30天,12月31天
141                 monthday = ["31", "29", "31", "30", "31", "30", "31", "31", "30", "31", "30", "31"];
142                 return monthday[month - 1];
143             } else {
144                 monthday = ["31", "28", "31", "30", "31", "30", "31", "31", "30", "31", "30", "31"];
145                 return monthday[month - 1];
146             }
147         }
148 
149     </script>
150 }
View Code
相關文章
相關標籤/搜索