使用JavaScript編寫萬年曆的程式代碼

来源:http://www.cnblogs.com/xuanya/archive/2017/05/22/6773777.html
-Advertisement-
Play Games

昨天,我接到的公司老司機的命令,要求我完成一個萬年曆,目的是想通過日曆來利用ajax顯示報名信息。平時不怎麼重視日曆的我遇到了很多麻煩,幸好在公司的一臺機器上找到了問題解決的思路。雖然不知道這位sir是誰,但是我還是要感謝他,他的思路讓我明白了什麼是閏年,什麼是小月大月,跳轉月份的規則...總之,如 ...


昨天,我接到的公司老司機的命令,要求我完成一個萬年曆,目的是想通過日曆來利用ajax顯示報名信息。平時不怎麼重視日曆的我遇到了很多麻煩,幸好在公司的一臺機器上找到了問題解決的思路。雖然不知道這位sir是誰,但是我還是要感謝他,他的思路讓我明白了什麼是閏年,什麼是小月大月,跳轉月份的規則...總之,如果你看到了的話煩請您聯繫我一聲,我會擺平所有的阻礙為你獻上一捲衛生紙表達感激!

 

接下來就是萬年曆小程式的內容(使用js編寫):

1:HTML層

 1 <!DOCTYPE html>
 2 <html>
 3 <head lang="en">
 4     <meta charset="UTF-8">
 5     <title>日曆</title>
 6     <link rel="stylesheet" type="text/css" href="Calendar.css">
 7     <script type="text/javascript" src="Calendar.js"></script>
 8 </head>
 9 <body>
10     <div id="calendar" class="calendar">
11         <div class="prev">
12             <button id="prev_M">上個月</button>
13         </div>
14 
15         <span id="month"></span><span id="year"></span>16 
17         <div class="next">
18             <button id="next_M">下個月</button>
19         </div>
20     </div>
21 
22     <div style="clear:both"></div>
23     <!--日曆主體-->
24     <div id="calendar_weektitle"></div>
25     <div id="calendar_weekday"></div>
26     <div style="clear:both;"></div>
27     <!--報名信息-->
28     <div id="regis"><span id="reg_i" style="color:green;"></span> 是否可報名</div>
29     <div id="instalment">月份/批次</div>
30 </body>
31 </html>

 

2:CSS ceng

 1 .calendar{
 2     font-family: "-apple-system", "Helvetica Neue", "Roboto", "Segoe UI", sans-serif;
 3     width: 490px;
 4     text-align: center;
 5     overflow: hidden;
 6 }
 7 #calendar_weekday{
 8     width: 500px;
 9 }
10 #calendar_weektitle{
11     width: 500px;
12 }
13 .prev{
14     cursor: pointer;
15     float: left;
16     /*            padding-right: px;*/
17 }
18 .next{
19     cursor: pointer;
20     float: right;
21     /*            padding-right: px;*/
22 }
23 
24 #calendar_weekday div,#calendar_weektitle div{
25     border-bottom: 1px solid #cccccc;
26     font-size: 11px;
27     font-family: "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
28 }
29 #calendar_weekday div{
30     color: #adadad;
31 }
32 #calendar_weekday > div:hover{
33     background-color: #ffcd3c;
34     opacity: .5;
35 }
36 #regis,#instalment{
37     line-height: 35px;
38     font-family: "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
39     font-size: 14px;
40     width: 490px;
41     padding-left: 20px;
42 }
43 #regis{
44     background-color: #ffd96a;
45     height: 40px;
46 }
47 #instalment{
48     border-bottom: 1px solid red;
49     /*line-height: 30px;*/
50     height: 36px;
51 }

 

3:javascript ceng !important

  1 /**
  2  * Created by heart on 2017/4/26.
  3  */
  4 window.onload = function(){
  5     //為日曆寫入月份頭部
  6     function Calendar(){
  7         var weeks = ['日', '一', '二', '三', '四', '五', '六'];
  8         for(i = 0; i < weeks.length; i++){
  9             var div = document.createElement('div');
 10             div.id = 'week_' + i;
 11             div.innerHTML = weeks[i];
 12             div.style.width = '14%';
 13             div.style.height = '35px';
 14             div.style.lineHeight = div.style.height;
 15             div.style.backgroundColor = '#ccc';
 16             div.style.float = 'left';
 17             div.style.textAlign = 'center';
 18             document.getElementById('calendar_weektitle').appendChild(div);
 19         }
 20         alert("1");
 21     }
 22 
 23     //構造原型對象
 24     Calendar.prototype = {
 25         //取閏年函數
 26         isLeap : function(year){
 27             return (year % 100 !== 0 && year % 4 == 0) || (year % 400 == 0);
 28         },
 29         //返回本年本月的天數
 30         getDaysNum : function(year, month) {
 31             var num = 31;           //大月
 32             switch (month) {
 33                 case '2':
 34                     num = this.isLeap(year) ? 29 : 28;
 35                     break;         //小月
 36                 case 4:
 37                 case 6:
 38                 case 9:
 39                 case 11:
 40                     num = 30;
 41                     break;
 42             }
 43             return num;
 44         },
 45         //返回本月的第一天是周幾
 46         getWeek : function(year, month){
 47             var d = new Date();
 48             // var m=d.getMonth()+1;
 49             // var y=d.getYear();
 50 
 51             d.setYear(year);
 52             d.setMonth(month-1);
 53             d.setDate(1);
 54             var weeks = ['7', '1', '2', '3', '4', '5', '6'];
 55             return weeks[d.getDay()];
 56 
 57         },
 58         //核心函數,寫入日曆
 59         show : function(year, month){
 60             var weekFirstDay = this.getWeek(year, month);
 61             var dayCount = this.getDaysNum(year, month);
 62             console.log(weekFirstDay);
 63             //得到本月頭是周幾,併在前面插入空天數
 64             if(weekFirstDay != '7'){
 65                 for(var i = 0; i < weekFirstDay; i++){
 66                     var div_1 = document.createElement('div');
 67                     div_1.style.cursor = 'pointer';
 68                     div_1.innerHTML = '';
 69                     div_1.style.width = '14%';
 70                     div_1.style.height = '40px';
 71 //                    div_1.style.lineHeight = div_1.style.height / 2;
 72                     div_1.style.float = 'left';
 73                     div_1.style.textAlign = 'center';
 74                     document.getElementById('calendar_weekday').appendChild(div_1);
 75                 }
 76             }
 77             //得到本月的天數,按規則格式註入天數
 78             for(i = 0; i < dayCount; i++){
 79                 var div_2 = document.createElement('div');
 80                 div_2.style.cursor = 'pointer';
 81                 div_2.id = 'day_' + year + '_' + month + '_' + (i + 1);
 82                 console.log(div_2.id);
 83                 div_2.innerHTML = i + 1 + '<br />';
 84                 div_2.style.width = '14%';
 85                 div_2.style.height = '40px';
 86 //                div_2.style.lineHeight = div_2.style.height / 2;
 87                 div_2.style.float = 'left';
 88                 div_2.style.textAlign = 'center';
 89                 document.getElementById('calendar_weekday').appendChild(div_2);
 90             }
 91 
 92         },
 93         //跳轉上個月,月份減一
 94         PreMonth: function() {
 95             this.PreDraw(new Date(this.Year, this.Month - 2, 1));
 96         },
 97         //跳轉下個月,月份加一
 98         NextMonth: function() {
 99             this.PreDraw(new Date(this.Year, this.Month, 1));
100         },
101         //重繪
102         PreDraw: function(date) {
103             this.Year = date.getFullYear();
104             this.Month = date.getMonth() + 1;
105             this.Draw();
106         }
107     };
108     alert('2');
109     //對象實例化
110     Calen = new Calendar();
111     //獲取本地時間
112     var  data= new Date();
113     m = data.getMonth()+1;
114     y =data.getFullYear();
115     d = data.getDate();
116     //寫入本月天數
117     Calen.show(y,m);
118     var today = document.getElementById('day_'+ y + '_'+ m + '_' + d);
119     today.style.backgroundColor = '#ffcd3c';
120 
121     document.getElementById("year").innerHTML = y;
122     document.getElementById("month").innerHTML = m;
123     alert('3');
124     //跳轉到下個月
125     document.getElementById("next_M").onclick = function(){
126         var  div=document.getElementById("calendar_weekday");
127         div.innerHTML = "";
128         if(m > 0&&m < 12){
129             m += 1;
130         }else if(m > 1){
131             m = 1;
132             y += 1;
133         }else if(m == 12){
134             m = 1;
135             y += 1;
136         }
137         Calen.show(y, m);
138         document.getElementById("year").innerHTML = y;
139         document.getElementById("month").innerHTML = m;
140     };
141 
142     //跳轉到上一月
143     document.getElementById("prev_M").onclick = function(){
144         var div = document.getElementById("calendar_weekday");
145         div.innerHTML="";
146         if(m > 1 && m < 12){
147             m -= 1;
148         }else if(m <= 1){
149             m = 12;
150             y-=1;
151         }else if(m == 12){
152             m -= 1;
153         }
154         Calen.show(y, m);
155         document.getElementById("year").innerHTML = y;
156         document.getElementById("month").innerHTML = m;
157     };
158 };

 對於js程式,我使用的是javascript原型對象開發模式,個人覺得在較複雜的程式中它相對函數式模式更加可視直觀。相關的細節描述已在代碼的註釋中標識;可能在動態樣式上有所不足;可能需要在功能上有所補充;代碼可取走分析使用。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 canvas 強大的功能讓它成為了 HTML5 中非常重要的部分,至於它是什麼,這裡就不需要我多作介紹了。而可視化圖表,則是 canvas 強大功能的表現之一。 現在已經有了很多成熟的圖表插件都是用 canvas 實現的,Chart.js、ECharts等可以製作出好看炫酷的圖表,而且幾乎覆蓋 ...
  • 今天在學習HTML5的過程中遇到了中文亂碼問題: 我是用myeclipse 2016開發的,但我的項目和html文件的編碼格式都是utf-8,還是亂碼,去網上搜了搜都沒有搜到,後來發現了一件有趣的事,知道了問題的原因。 每次創建一個新的HTML5文件時,新建的文件都自帶瞭如下代碼: 但當我嘗試著把 ...
  • 實現效果 如圖所示: 首先得準備三張圖,一張是淺黃色的背景圖loading_bg.png,一張是深紅色的圖loading.png,最後一張為bolang.png。 css代碼 html代碼 ...
  • ECMAScript 的語法大量借鑒了C及其他類C語言(如Java 和Perl)的語法。 1. 區分大小寫 2.標識符 2.1 第一個字元必須是一個字母、下劃線(_)或一個美元符號($); 2.2 其他字元可以是字母、下劃線、美元符號或數字 按照慣例,ECMAScript標識符採用駝峰大小寫格式,也 ...
  • 一、相對定位(position:relative) 如果想讓一個元素在本來的位置進行一個位移,可以將該元素的定位設置為relative,同時指定相對位移(利用top,bottom,left,right).需要註意的是,元素仍然在文檔流中,占據著它本來的位置空間. 二、絕對定位(position:ab ...
  • 工作中接到新項目,開發前都需要先規劃項目目錄,然後一個個創建文件,搭建sass編譯環境,下載jquery,Swiper等類庫... 這些準備工作都要花上不少時間。每做一個項目,都會遇到同樣的問題,再重覆一遍嗎? 是時候做點改變了:編寫自己的cli工具,一行命令,3秒鐘進入coding狀態! 本文以自 ...
  • JavaWeb一--瀏覽器技術 一、HTTP協議 1.1 HTTP定義 HTTP(Hypertext Transport Protocol),超文本傳輸協議。 一種詳細規定了瀏覽器和web伺服器之間互相通信的規則,通過網際網路傳送萬維網文檔的數據傳送協議。 1.2 協議原理 1.3 請求格式 * 第一 ...
  • 項目的需要,要整一個視頻直播,但又不想在其他平臺那種直播室盜鏈展示,那我就直接用播放器來實現rtmp流媒體伺服器推流吧!沒廢話,走起 1.你要有一個媒體伺服器,暫時用【盤古雲】,這個還好,算是不錯的平臺了。註冊就能用,貌似免費的一樣,哈哈不管那麼多先搭建一個,看圖: 圖解:【1】菜單,進入創建一個媒 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...