HTML+JavaScript自己动手做日历 您所在的位置:网站首页 生成日历的前端代码 HTML+JavaScript自己动手做日历

HTML+JavaScript自己动手做日历

2024-04-05 09:15| 来源: 网络整理| 查看: 265

当我们需要在页面中显示某月的事项,或是选择某一段日期时,常常要使用到日历组件。这一组件同样有着许多现成的类库,然而亲自动手开发一个日历,从中了解其实现原理也是非常必要的。在本例中我们就将制作一款非常经典的日历组件。

1. 创建DOM代码

本例的HTML代码如下:

Month Year Prev Month Next Month MON TUE WED THU FRI SAT SUN

由以上代码可见,日历的最外层是一个类名为calendar的div元素,其内部包含了两大部分,分别是日历顶部的标题区域,其类名为title,以及其下方的日期区域,其类名为body。

在title中包含了当前所选日期的月份、年份,其id分别为calendar-title和calendar-year,此外该元素还包括了prev和next两个按钮,分别用于切换选择上一月和下一月。

在body中首先包含了一个周一到周日的英文表头,它们放在一个ul元素中。在表头之后是另一个div元素,用于显示日历主体。其中,日历所选月份的每一天都将显示在该元素内部的days列表中。

2. CSS样式

本例中大部分的基础CSS样式省略介绍,在此仅介绍其中的body-list类。该类用于设置日历表头和日期数据的栅格显示。我们将整个ul元素的宽度设置为100%,并将其除以7,就可以得到每一个li元素的宽度,即14.28%,将这些元素左浮动显示,就可以得到日期的7列显示,样式代码如下:

.calendar{ width:450px; height:350px; background:#fff; box-shadow:0px 1px 1px rgba(0,0,0,0.1); } .body-list ul{ width:100%; font-family:arial; font-weight:bold; font-size:14px; } .body-list ul li{ width:14.28%; height:36px; line-height:36px; list-style-type:none; display:block; box-sizing:border-box; float:left; text-align:center; }

此外,我们为今天、今天之前及今天之后的日期分别创建了不同的类。其中,用浅灰色来显示过去的日期,深灰色来显示将来的日期,日期当天则使用浅绿色背景、绿色文字加以显示,样式代码如下:

.lightgrey{ color:#a8a8a8; /*浅灰色*/ } .darkgrey{ color:#565656; /*深灰色*/ } .green{ color:#6ac13c; /*绿色*/ } .greenbox{ border:1px solid #6ac13c; background:#e9f8df; /*浅绿色背景*/ }

日历组件的初始显示效果如下图所示。

3. JavaScript生成日历

接着使用JavaScript来动态生成日历信息。首先,我们要做一些前期的准备工作。由于闰年和非闰年的二月天数是不一样的,在此我们为这两种年份分别创建数组,以便于获取每个月的天数,同时为每个月份的英文名创建相应的数组变量,代码如下:

var month_olympic = [31,29,31,30,31,30,31,31,30,31,30,31]; var month_normal = [31,28,31,30,31,30,31,31,30,31,30,31]; var month_name = ["January","Febrary","March","April","May","June","July","Auguest","September","October","November","December"];

然后,为页面中的各种元素创建变量,以便于后续的引用,代码如下:

var holder = document.getElementById("days"); var prev = document.getElementById("prev"); var next = document.getElementById("next"); var ctitle = document.getElementById("calendar-title"); var cyear = document.getElementById("calendar-year");

创建一个Date对象来获取当前的日期时间,并通过getFullYear()方法来获取当前年份,getMonth()方法来获取月份,getDate()方法来获取当前日期。代码如下:

var my_date = new Date(); var my_year = my_date.getFullYear(); var my_month = my_date.getMonth(); var my_day = my_date.getDate();

我们要实现日历的排布,最关键的问题是要知道某一月第一天究竟是星期几,然后才可以根据当月的天数来依次排列其后的日期。在此,专门为该功能创建一个函数,代码如下:

//获取某年某月第一天是星期几 function dayStart(month, year) { var tmpDate = new Date(year, month, 1); return (tmpDate.getDay()); }

此外,我们也创建一个相应的函数来获取某月的总天数,代码如下:

//计算某年是不是闰年,通过求年份除以4的余数即可 function daysMonth(month, year) { var tmp = year % 4; if (tmp == 0) { return (month_olympic[month]); } else { return (month_normal[month]); } }

然后,创建一个refreshDate函数来生成月份显示,代码如下:

function refreshDate(){ var str = ""; var totalDay = daysMonth(my_month, my_year); //获取该月总天数 var firstDay = dayStart(my_month, my_year); //获取该月第一天是星期几 var myclass; for(var i=1; i


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有