欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

JS實現(xiàn)一個簡單的日歷

主要分為三個部分,1:獲取li元素 2:如何填寫對應(yīng)的日期 3:如何獲取點擊li元素的事件。

企業(yè)建站必須是能夠以充分展現(xiàn)企業(yè)形象為主要目的,是企業(yè)文化與產(chǎn)品對外擴展宣傳的重要窗口,一個合格的網(wǎng)站不僅僅能為公司帶來巨大的互聯(lián)網(wǎng)上的收集和信息發(fā)布平臺,創(chuàng)新互聯(lián)公司面向各種領(lǐng)域:水泥攪拌車網(wǎng)站設(shè)計、網(wǎng)絡(luò)營銷推廣解決方案、網(wǎng)站設(shè)計等建站排名服務(wù)。


1:通過節(jié)點間關(guān)系的屬性children 獲取li元素(兩個for循壞遍歷);

2:在遍歷填寫日期時,在第一行判斷在當月的第一天在星期幾,然后從第一天開始填寫,直到大于當月的天數(shù)就暫停填寫,并開始填寫下個月的日期。第一行上個月的日期顯示  : 上月天數(shù)顯示開始值 = 計算上個月的天數(shù) - 這個月開始的第一天在星期幾的值 -1,然后在第一行上月天數(shù)顯示開始值自加。

3:利用JS的事件冒泡獲取li的innerHTML顯示出對應(yīng)日期

效果圖:

JS實現(xiàn)一個簡單的日歷

代碼如下:

<!doctype html>
<html lang="en">
 <head>
 <meta charset="UTF-8">
 <meta name="Generator" content="EditPlus®">
 <meta name="Author" content="">
 <meta name="Keywords" content="">
 <meta name="Description" content="">
 <title>calendar</title>
 <style>
 .clear:after{
 content:"";
 display:table;
 clear:both;
 }
 .left{
 float:left;
 }
 ul{
 padding:0px;
 margin-top:5px;
 margin-bottom:0px;
 }
 ul>li{
 float:left;
 list-style:none;
 width:30px;
 height: 21px;
 border: 1px solid #ccc;
 text-align:center;
 }
 .gray{
 color:#766565;
 }
 .top {
 height:25px;
 }
 .top .lf-tri{
 border:10px solid transparent;
 border-right-color:black;
 margin-top:4px;
 }
 .top .rf-tri{
 border:10px solid transparent;
 border-left-color:black;
 margin-top:4px;
 }
 .top .content{
 width:185px;
 height:5px;
 text-align:center;
 }
 </style>
 </head>
 <body> 
 <div class="top clear">
 <div class="left lf-tri" onclick="lastMonth()"></div>
 <div class="left content">2017年2月1日</div>
 <div class="left rf-tri" onclick=" nextMonth()"></div>
 </div>
 <div>
 <div id="week">
 <ul class="clear">
 <li>日</li>
 <li>一</li>
 <li>二</li>
 <li>三</li>
 <li>四</li>
 <li>五</li>
 <li>六</li>
 <ul>
 </div>
 <div id="date" onclick='getDateNum(event)'>
 <ul class="clear">
 <li>30</li>
 <li>31</li>
 <li>1</li>
 <li>2</li>
 <li>3</li>
 <li>4</li>
 <li>5</li>
 </ul>
 <ul class="clear">
 <li>6</li>
 <li>7</li>
 <li>8</li>
 <li>9</li>
 <li>10</li>
 <li>11</li>
 <li>12</li>
 </ul>
 <ul class="clear">
 <li>13</li>
 <li>14</li>
 <li>15</li>
 <li>16</li>
 <li>17</li>
 <li>18</li>
 <li>19</li>
 </ul>
 <ul class="clear">
 <li>20</li>
 <li>21</li>
 <li>22</li>
 <li>23</li>
 <li>24</li>
 <li>25</li>
 <li>26</li>
 </ul>
 <ul class="clear">
 <li>27</li>
 <li>28</li>
 <li>1</li>
 <li>2</li>
 <li>3</li>
 <li>4</li>
 <li>5</li>
 </ul>
 <ul class="clear">
 <li>27</li>
 <li>28</li>
 <li>1</li>
 <li>2</li>
 <li>3</li>
 <li>4</li>
 <li>5</li>
 </ul>
 </div>
 <div>
 <script>
 function $(id){
 return document.getElementById(id);
 }
 function change(cls){
 return document.getElementsByClassName(cls);
 }
 function getDateNum(e) {
 console.log(e && e.target.nodeName)//打印發(fā)生事件的元素,再獲取元素nodeName
 if(e.target.nodeName=="LI"){//先判斷nodeName是LI
 if(e.target.className!="gray"){//點擊本月的日期,顯示在日期欄
 change("content")[0].innerHTML = year+'年'+(month+1)+'月'+e.target.innerHTML+'日';
 }else{//點擊灰色日期即(上個月或者下個月日期)切換到當月
 if(e.target.innerHTML>14){
 lastMonth();
 }else {
 nextMonth();
 }
 }
 }
 }
 //獲取年、月
 var today = new Date();
 var year=today.getFullYear(), month = today.getMonth();
 var totalDay;
 var uls=$("date").children,list;
 function loadCalendar(){
 totalDay=getMonthDays(year,month+1);//計算一個月的天數(shù)
 var firstDay = (new Date(year,month,1)).getDay();//計算每個月1號在星期幾
 var lastMonthDay=getMonthDays(year,month);
 var lastDayCal=lastMonthDay-firstDay+1;//計算上個月在第一行顯示的天數(shù)
 //獲取ul元素
 var num=1 ,nextNum=1;//日期顯示
 // 類數(shù)組對象 轉(zhuǎn) 數(shù)組
 //uls = Array.prototype.slice.call(uls)
 //獲取li元素 填充
 for(var r=0;r<uls.length;r++){
 list=uls[r].children;//遍歷ul,獲得li
 for(var line=0;line<list.length;line++){
 if(r==0){//在第一行 與第一天進行判斷 大于等于第一天時載入日期
 if(line>=firstDay){
 list[line].innerHTML=num++;
 list[line].setAttribute("class","");
 }else {
 list[line].innerHTML=lastDayCal++;//第一行的上個月天數(shù)顯示
 list[line].setAttribute("class","gray");
 }
 }else {
 //判斷是否超出天數(shù) ,不超出則繼續(xù)加,超出則顯示下個月日期
 if(num<=totalDay){
 list[line].setAttribute("class","");
 list[line].innerHTML=num++;
 }else {
 list[line].innerHTML=nextNum++;//下個月日期顯示
 list[line].setAttribute("class","gray");
 }
 }
 }
 }
 }
 loadCalendar();
 function getMonthDays(year,month){
 //判斷2月份天數(shù)
 if(month==2){
 days= (year%4==0)&&(year%100!=0)||(year%400==0)? 29:28;
 }else {
 //1-7月 單數(shù)月為31日 
 if(month<7){
 days= month%2==1?31:30;
 }else {
 //8-12月 雙月為31日
 days = month%2==0?31:30;
 }
 }
 return days; 
 }
 //右擊箭頭下個月
 //change("rf-tri")[0].onclick =
 function nextMonth() {
 month++;
 if(month>11){
 year+=1;
 month=0;
 }
 change("content")[0].innerHTML=year+"年"+(month+1)+"月"+"1日";
 //console.log(month+1);
 loadCalendar();
 }
 //左擊箭頭上個月
 //change("lf-tri")[0].onclick =
 function lastMonth() {
 month--;
 if(month<0){
 month=11;
 year-=1;
 }
 change("content")[0].innerHTML=year+"年"+(month+1)+"月"+"1日";
 //console.log(month+1);
 loadCalendar();
 }
 </script>
 </body>
</html>

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持創(chuàng)新互聯(lián)!

文章標題:JS實現(xiàn)一個簡單的日歷
本文來源:http://aaarwkj.com/article46/psogeg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計企業(yè)網(wǎng)站制作、品牌網(wǎng)站建設(shè)標簽優(yōu)化、定制網(wǎng)站、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
精品一区无遮挡免费网站| 热门精品一区二区三区| 日韩精品一区二区三区人妻视频| 亚洲第一国产综合自拍| 午夜av在线毛片免费观看| 人妻口爆视频一区二区三区| 久久精品性少妇一区二区三区| 久久综合婷婷亚洲色图 | 日韩中字伦理熟妇人妻| 国产av高清视频在线| 成年女人毛片免费观看不卡| 一区二区三区毛片观看| 日韩商清av毛片网站| 亚洲精品欧美无人区乱码| 91精品国产成人在线| 亚洲精品国产高清久久| 亚洲av不卡一区二区在线观看| 欧美日韩国产综合在线观看| 做性视频大全在线观看| 伊人激情一区二区三区| 欧美激情日韩精品久久久| 97视频观看免费观看| 后入视频国产在线观看| 蜜臀91精品视频在线观看| 日韩视频一区二区三区系列| 欧美亚洲国产青草久久| 99精品人妻一区二区三区蜜桃| 综合久久99中文综合久久| 久久精品欧美日韩视频| 在线观看免费国产b片| 乱色熟女一区二区三区| 亚洲伦理av在线观看| 日韩黄国产一区二区三| 欧美成人午夜精品一区二区| 精品国产乱码久久蜜桃| 亚洲精品色婷婷一区二区| 国产黄色一区二区三区| 日本精品1区国产精品| 亚洲欧美综合日韩综合久久久| 国欧美一区二区三区| 亚洲欧美一区二区色慰|