欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實(shí)現(xiàn)簡(jiǎn)單日歷效果

 更新時(shí)間:2020年09月11日 08:49:11   作者:qq_38455564  
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單日歷效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)簡(jiǎn)單日歷效果的具體代碼,供大家參考,具體內(nèi)容如下

實(shí)現(xiàn)效果:

根據(jù)所選擇的年月,列出當(dāng)月對(duì)應(yīng)是周幾,效果圖如下:

實(shí)現(xiàn)思路:

1、使用select標(biāo)簽保存年月的所選菜單。使用table標(biāo)簽保存當(dāng)月天數(shù),表頭為固定的周日周一等。

2、使用option對(duì)象,給年月循環(huán)賦值。

3、將每月的天數(shù)保存到數(shù)組中,根據(jù)所選的年月獲取當(dāng)月的天數(shù),以及當(dāng)月一號(hào)對(duì)應(yīng)周幾,對(duì)應(yīng)周幾就在第一行先打印幾個(gè)空格,然后從一號(hào)開始依次打印當(dāng)月天數(shù)。

4、刷新年月時(shí),清除上次表格中(除表頭的周)的數(shù)據(jù),重新填入數(shù)據(jù)。

代碼實(shí)現(xiàn):

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <!--CSS樣式-->
 <style type="text/css">
 *{margin: 0px;padding: 0px;}
 #div{width: 400px;height: 300px;border: 1px solid red;margin: auto;}
 #div div:nth-child(1){display: flex;align-items: center;justify-content: center;}
 #tbcal{border-collapse: collapse;width: 100%;text-align: center;}
 #tbcal tr td{border: 1px solid red;}
 </style>
 <script type="text/javascript">
// 加載完HTML內(nèi)容后,JavaScript開始執(zhí)行
 window.onload=function(){
 initial();
 document.getElementById("selyear").onchange=show;
 document.getElementById("selmonth").onchange=show;
 show();
 }
// 顯示日歷
 function show(){
// 獲取鼠標(biāo)點(diǎn)擊所選擇的年月值
 var year=parseInt(document.getElementById("selyear").value);
 var month=parseInt(document.getElementById("selmonth").value);
// 判斷是否為閏年,以便確定2月的天數(shù)
 var flag=year%4==0&&year%100!=0||year%400==0;
 var dayofmonth=[31,flag?29:28,31,30,31,30,31,31,30,31,30,31];
// 給date賦值,值為所選擇的某年某月一號(hào)
 var dt=new Date();
 dt.setFullYear(year);
 dt.setMonth(month-1);
 dt.setDate(1);
// 獲取date對(duì)應(yīng)周幾
 var week=dt.getDay();
// 當(dāng)月應(yīng)該打印多少行
 var rows=Math.ceil((dayofmonth[dt.getMonth()]+week)/7);
 var k=0;
// 如果表格中有除表頭外的數(shù)據(jù),進(jìn)行數(shù)據(jù)刪除,避免上次月份的數(shù)據(jù)對(duì)下次有影響
 var table=document.getElementById("tbcal");
 while(table.rows.length>1){
  table.deleteRow(1);
  
 }
// 循環(huán)向表格中添加數(shù)據(jù),生成日歷
 for(var i=0;i<rows;i++){
  var row=table.insertRow(i+1);
  for(var j=0;j<7;j++){
  var cell=row.insertCell(j);
  k++;
  if(k<=week || k>dayofmonth[dt.getMonth()]+week){
  cell.innerHTML="";
  }
  else{
  cell.innerHTML=k-week;
  }
  }
 }
 }
// 通過option對(duì)象向年月中循環(huán)賦值
 function initial(){
 var years=document.getElementById("selyear");
 var months=document.getElementById("selmonth");
 for (var i=1990;i<2019;i++) {
  var option=document.createElement("option");
  option.text=i;
  years.add(option);
 }
 for (var i=1;i<13;i++) {
  var option=document.createElement("option");
  option.text=i;
  months.add(option);
 }
 }
 </script>
 </head>
 <body>
 <div id="div">
 <!--定義年月菜單-->
 <div>
 <select id="selyear"></select>&nbsp;年&nbsp;
 <select id="selmonth"></select>&nbsp;月&nbsp;
 </div>
 <div>
 <!--定義列表-->
 <table id="tbcal">
  <tr>
  <td>周日</td>
  <td>周一</td>
  <td>周二</td>
  <td>周三</td>
  <td>周四</td>
  <td>周五</td>
  <td>周六</td>
  </tr>
 </table>
 </div>
 </div>
 </body>
</html>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • tablesorter.js表格排序使用方法(支持中文排序)

    tablesorter.js表格排序使用方法(支持中文排序)

    這篇文章主要為大家詳細(xì)介紹了tablesorter.js表格排序使用方法,支持中文排序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 如何用JavaScript檢測(cè)當(dāng)前瀏覽器是無頭瀏覽器

    如何用JavaScript檢測(cè)當(dāng)前瀏覽器是無頭瀏覽器

    這篇文章主要介紹了如何用JavaScript檢測(cè)當(dāng)前瀏覽器是無頭瀏覽器,對(duì)無頭瀏覽器感興趣的同學(xué),可以參考一下
    2021-04-04
  • 基于javascript的JSON格式頁面展示美化方法

    基于javascript的JSON格式頁面展示美化方法

    本文介紹的方法基于javascript,css和myFunction結(jié)合可實(shí)現(xiàn)頁面展示轉(zhuǎn)換,下面有個(gè)示例,大家可以參考下
    2014-07-07
  • 如何計(jì)算Web動(dòng)畫幀率FPS

    如何計(jì)算Web動(dòng)畫幀率FPS

    我們知道,動(dòng)畫其實(shí)是由一幀一幀的圖像構(gòu)成的。有Web動(dòng)畫那么就會(huì)存在該動(dòng)畫在播放運(yùn)行時(shí)的幀率。而幀率在不同設(shè)備不同情況下又是不一樣的。有的時(shí)候,一些復(fù)雜或者重要?jiǎng)赢?,需要?shí)時(shí)監(jiān)控它們的幀率,從而更好的優(yōu)化它們,本文就是介紹Web動(dòng)畫幀率(FPS)計(jì)算方法。
    2021-05-05
  • 原生js實(shí)現(xiàn)貪吃蛇游戲

    原生js實(shí)現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • JS克隆,屬性,數(shù)組,對(duì)象,函數(shù)實(shí)例分析

    JS克隆,屬性,數(shù)組,對(duì)象,函數(shù)實(shí)例分析

    這篇文章主要介紹了JS克隆,屬性,數(shù)組,對(duì)象,函數(shù),結(jié)合實(shí)例形式分析了javascript中面向?qū)ο蟪绦蛟O(shè)計(jì)相關(guān)的對(duì)象、屬性、函數(shù)及數(shù)組等相關(guān)技巧,需要的朋友可以參考下
    2016-11-11
  • js實(shí)現(xiàn)精確到毫秒的倒計(jì)時(shí)效果

    js實(shí)現(xiàn)精確到毫秒的倒計(jì)時(shí)效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)精確到毫秒的倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Avalon中文長(zhǎng)字符截取、關(guān)鍵字符隱藏、自定義過濾器

    Avalon中文長(zhǎng)字符截取、關(guān)鍵字符隱藏、自定義過濾器

    avalon是一個(gè)簡(jiǎn)單易用迷你的MVVM框架。通過本文給大家介紹Avalon中文長(zhǎng)字符截取、關(guān)鍵字符隱藏、自定義過濾器的相關(guān)資料,需要的朋友一起學(xué)習(xí)吧
    2016-05-05
  • javascript制作sql轉(zhuǎn)換為stringBuffer的小工具

    javascript制作sql轉(zhuǎn)換為stringBuffer的小工具

    這篇文章主要介紹了javascript制作sql轉(zhuǎn)換為stringBuffer的小工具,使用方法很簡(jiǎn)單,吧寫好的sql語句只要格式化好之后放進(jìn)去就可以了,推薦給大家,有需要的小伙伴可以參考下。
    2015-04-04
  • JavaScript面向?qū)ο髮?shí)現(xiàn)放大鏡案例

    JavaScript面向?qū)ο髮?shí)現(xiàn)放大鏡案例

    這篇文章主要為大家詳細(xì)介紹了JavaScript面向?qū)ο髮?shí)現(xiàn)放大鏡案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10

最新評(píng)論