javascriptに基づいてカレンダーの機能原理とコードの実例を実現します。


カレンダー
javascriptを勉強しているうちに、初心者の教程にjavascriptの実例があります。cssカレンダーは面白いと思います。その上に簡単な機能が増えました。
機能
  • は、伝統的なカレンダーに従って、この月の毎日を表示します。
  • は今日の日付を強調表示することができます。
  • は前月と来月のカレンダーをめくることができます。
  • 実現する
  • step 1伝統的なカレンダーレイアウトスタイル:それぞれの年と月、月、月のすべての日数をリストレイアウトにし、伝統的なカレンダーを構成するスタイルを並べます。
  • step 2初期化と更新月:リストをクリアしてから、ある発見があります。初期化のリストにあるchildNodesは、プロジェクトの中でクリアする必要があります。それから、先頭の空白を記入します。
  • Step 3は、documentでリストオブジェクトを取得し、今日の対応する行のスタイルを変更して強調表示します。
  • 他の詳細はコードで実装されます。
  • コード
    htmlコード
    
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>CSS  </title>
    <link type="text/css" rel="stylesheet" href="style.css" rel="external nofollow" >
    </head>
    <body>
     
    	<h1>CSS  </h1> 
    	<div class="month">
    		<ul>
    			<li class="prev" onclick="change(-1)">❮</li>
    			<li class="next" onclick="change(1)">❯</li>
    			<li style="text-align: center"><span id="month">August</span><br>
    				<span style="font-size: 18px" id="year">2016</span></li>
    		</ul>
    	</div>
    
    	<ul class="weekdays" id="weekdays">
    
    	</ul>
    
    	<ul class="days" id="days">
    	</ul>
    </body>
    <script type="text/javascript" src="show.js"></script>
    </html>
    CSSコード
    
    @charset "UTF-8";
    * {box-sizing:border-box;}
    ul {list-style-type: none;}
    body {font-family: Verdana,sans-serif;}
    .center {
      text-align: center;
      border: 3px solid green;
    }
    
    .month {
      padding: 70px 25px;
      width: 100%;
      background: #1abc9c;
    }
    
    .month ul {
      margin: 0;
      padding: 0;
    }
    
    .month ul li {
      color: white;
      font-size: 20px;
      text-transform: uppercase;
      letter-spacing: 3px;
    }
    
    .month .prev {
      float: left;
      padding-top: 10px;
    }
    
    .month .next {
      float: right;
      padding-top: 10px;
    }
    
    .weekdays {
      margin: 0;
      padding: 10px 0;
      background-color: #ddd;
    }
    
    .weekdays li {
      display: inline-block;
      width: 13.6%;
      color: #666;
      text-align: center;
    }
    
    .days {
      padding: 10px 0;
      background: #eee;
      margin: 0;
    }
    
    .days li {
      list-style-type: none;
      display: inline-block;
      width: 13.6%;
      text-align: center;
      margin-bottom: 5px;
      font-size:12px;
      color: #777;
    }
    
    .days li active {
      padding: 5px;
      background: #1abc9c;
      color: white !important;
    }
    /* Add media queries for smaller screens */
    @media screen and (max-width:720px) {
      .weekdays li, .days li {width: 13.1%;}
    }
    
    @media screen and (max-width: 420px) {
      .weekdays li, .days li {width: 12.5%;}
      .days li .active {padding: 2px;}
    }
    
    @media screen and (max-width: 290px) {
      .weekdays li, .days li {width: 12.2%;}
    }
    javascriptコード
    
    var date = new Date();
    var year = date.getFullYear();
    var month=date.getMonth();
    var day = date.getDate();
    var week=date.getDay();
    var p=(week-day+1+35)%7+day-1;
    var monthName=[
    	"January","February","March","April","May","June","July","August","September","October","November","December"
    ];
    var monthNum=[
    	31,28,31,30,31,30,31,31,30,31,30,31
    ];
    var weekName=[
    	"Su","Mo","Tu","We","Th","Fr","Sa"
    ];
    var aimmonth=month,aimyear=year;
    
    function init(){
    	createTitle(year,month);
    	var weekdays=document.getElementById("weekdays");
    	for(var i=0;i<7;i++){ 
    		var x = document.createElement("LI");
    		var t = document.createTextNode(weekName[i]);
    		x.appendChild(t);
    		weekdays.appendChild(x);
    	}
    	delDay();
    	createDay();
    	isnow();
    }
    function change(x){ 
    	aimmonth+=x;
    	if(aimmonth==-1){
    		aimyear-=1;
    		aimmonth=11;
    	}else if(aimmonth==12){
    		aimyear+=1;
    		aimmonth=0;
    	}
    	createTitle(aimyear,aimmonth);
    	delDay(); 
    	createDay();
    	isnow();
    }
    function createTitle(y,m){
    	document.getElementById("year").innerHTML=y;
    	document.getElementById("month").innerHTML=monthName[m];
    }
    function createDay(){
    	var datetmp=new Date();
    	datetmp.setFullYear(aimyear,aimmonth,1);
    	var firstday=datetmp.getDay(); 
    	var days=document.getElementById("days"); 
    	
    	for(var i=0;i<firstday;i++){
    		var x = document.createElement("LI");
    		var t = document.createTextNode("");
    		x.appendChild(t);
    		days.appendChild(x);
    	}
    	for(var i=1;i<=getMonthDay();i++){ 
    		var x = document.createElement("LI");
    		var t = document.createTextNode(i);
    		x.appendChild(t);
    		days.appendChild(x);
    	} 
    }
    function delDay(){ 
    	var list=document.getElementById("days");
    	var len=list.childNodes.length; 
    	for(var i=0;i<len;i++){ 
    		list.removeChild(list.childNodes[0]);
    	}
    }
    function isnow(){ 
    	if(aimyear==year&&aimmonth==month){
    		days.childNodes[p].style="padding: 5px;background: #1abc9c;color: white !important;"
    	} 
    }
    function getMonthDay(){
    	if(aimmonth!=2){
    		return monthNum[aimmonth];
    	}else{
    		if(aimyear%4!=0||aimyear%100==0&&aimyear%400!=0){
    			return monthNum[aimmonth];
    		}
    		else return 29;
    	}
    } 
    //main
    init();
    締め括りをつける
    javascriptは今は初歩的で、最も基礎的な皮毛学会です。少なくともできないものは関数を探して、資料を調べて勉強します。実現するのはちょっと複雑かもしれませんが、最終的には自分の構想を表現できます。次は、いくつかの実例を書いてjqueryを見に行きます。
    cssはまだ不足しています。一部のものは衝突があるかもしれません。希望のものが実現できなくて、元のものを勉強しに帰ります。一番重要な点は多く訓練して、経験を積み、法則と思想をまとめます。
    以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。