基于javascript實(shí)現(xiàn)日歷功能原理及代碼實(shí)例
日歷
在學(xué)習(xí)javascript過(guò)程中,菜鳥(niǎo)教程有一個(gè)javascript實(shí)例---css日歷,感覺(jué)挺有趣的,在它的基礎(chǔ)上增加了一些簡(jiǎn)單的功能(差點(diǎn)哭遼)。
功能
- 按照傳統(tǒng)日歷方式顯示該月的每一天。
- 可以突出顯示今天的日期
- 可以翻閱上一個(gè)月和下一個(gè)月的日歷
實(shí)現(xiàn)
- step1 傳統(tǒng)日歷布局樣式:分別將年份與月份、星期、該月的全部天數(shù)采用列表布局,排列組成傳統(tǒng)日歷的樣式。
- step2 初始化和更新月份:先將列表清空(debug過(guò)程中,有一個(gè)發(fā)現(xiàn),初始化的列表便存在的一個(gè)childNodes,該項(xiàng)目中需要清空),然后再填入前導(dǎo)空白(為了和星期能夠?qū)?yīng)),再填入具體某一個(gè)月的天數(shù)。
- step3 通過(guò)document獲取列表對(duì)象,改變今天對(duì)應(yīng)行的樣式(className變化)來(lái)突出顯示。
- 其他細(xì)節(jié)在代碼中實(shí)現(xiàn)
代碼
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();
總結(jié)
javascript目前算是起步,最最基礎(chǔ)的皮毛學(xué)會(huì)了,起碼不會(huì)的東西可以通過(guò)去找函數(shù),查資料學(xué)習(xí),可能實(shí)現(xiàn)的有些復(fù)雜,但是最終能夠表達(dá)出自己的構(gòu)想,聽(tīng)開(kāi)心的。下一步,再寫(xiě)一些實(shí)例去看jquery。
css仍是不足,有些東西可能會(huì)有沖突,無(wú)法實(shí)現(xiàn)想要的東西,仍要回去學(xué)基礎(chǔ)的東西,最重要的一點(diǎn)是多練,積累經(jīng)驗(yàn),總結(jié)規(guī)律和思想。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 如何通過(guò)JS實(shí)現(xiàn)日歷簡(jiǎn)單算法
- 原生JS實(shí)現(xiàn)相鄰月份日歷
- JavaScript實(shí)現(xiàn)簡(jiǎn)單日歷效果
- 原生js實(shí)現(xiàn)日歷效果
- JS實(shí)現(xiàn)簡(jiǎn)單日歷特效
- js實(shí)現(xiàn)簡(jiǎn)單的日歷顯示效果函數(shù)示例
- 原生JavaScript實(shí)現(xiàn)日歷功能代碼實(shí)例(無(wú)引用Jq)
- JS實(shí)現(xiàn)帶陰歷的日歷功能詳解
- javascript實(shí)現(xiàn)考勤日歷功能
- 原生JS實(shí)現(xiàn)日歷組件的示例代碼
- js實(shí)現(xiàn)日歷
相關(guān)文章
Bootstrap基本布局實(shí)現(xiàn)方法詳解
這篇文章主要為大家詳細(xì)介紹了Bootstrap基本布局實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
js倒計(jì)時(shí)小實(shí)例(多次定時(shí))
這篇文章主要介紹了js實(shí)現(xiàn)可多次定時(shí)的倒計(jì)時(shí)小實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
理解Javascript的動(dòng)態(tài)語(yǔ)言特性
這篇文章主要介紹了理解Javascript的動(dòng)態(tài)語(yǔ)言特性,需要的朋友可以參考下2015-06-06
解決layui的table插件無(wú)法多層級(jí)獲取json數(shù)據(jù)的問(wèn)題
今天小編就為大家分享一篇解決layui的table插件無(wú)法多層級(jí)獲取json數(shù)據(jù)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
使用BootStrapValidator完成前端輸入驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了使用BootStrapValidator來(lái)完成前端輸入驗(yàn)證,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09

