最近的一个项目中,需要将数据用日历方式显示,网上有很多的JS插件,后面为了自己能有更大的控制权,决定自己制作一个日历显示。如下图所示:

一、计算数据

1、new一个Calendar类

2、初始化两个下拉框中的数据,年份与月份

3、初始化要搜索的年份和月份

4、计算得出日历中每一天的数据信息,包括css、天数

require_once 'calendar.php';

$util = new Calendar();

$years = array(2012, 2013, 2014, 2015, 2016);//年份选择自定义

$months = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12);//月份数组

//获取post的年份数据

if(empty($_POST['ddlYear'])) {

$year = date('Y');

}else {

$year = $_POST['ddlYear'];

}

//获取post的月份数据

if(empty($_POST['ddlMonth'])) {

$month = date('n');

}else {

$month = $_POST['ddlMonth'];

}

$calendar = $util->threshold($year, $month);//获取各个边界值

$caculate = $util->caculate($calendar);//计算日历的天数与样式

$draws = $util->draw($caculate);//画表格,设置table中的tr与td

?>

二、html展示

1、休息天的背景色是不同的,不是当前搜索年月的天数字体颜色也是不同的

2、div中做初始化年份与月份的下拉框的操作,并选中当前要搜索的年月

3、数据已计算好,哪个td属于哪个tr也已做好,直接将table打印出来即可

><?php echo $data?>

><?php echo $data?>

日一二三四五六

三、Calendar类1、threshold方法,生成日历的各个边界值

1)计算这个月总天数

2)计算这个月第一天与最后一天,各是星期几

3)计算日历中的第一个日期与最后一个日期

/**

* @deprecated 生成日历的各个边界值

* @param string $year

* @param string $month

* @return array

*/

function threshold($year, $month) {

$firstDay = mktime(0, 0, 0, $month, 1, $year);

$lastDay = strtotime('+1 month -1 day', $firstDay);

//取得天数

$days = date("t", $firstDay);

//取得第一天是星期几

$firstDayOfWeek = date("N", $firstDay);

//获得最后一天是星期几

$lastDayOfWeek = date('N', $lastDay);

//上一个月最后一天

$lastMonthDate = strtotime('-1 day', $firstDay);

$lastMonthOfLastDay = date('d', $lastMonthDate);

//下一个月第一天

$nextMonthDate = strtotime('+1 day', $lastDay);

$nextMonthOfFirstDay = strtotime('+1 day', $lastDay);

//日历的第一个日期

if($firstDayOfWeek == 7)

$firstDate = $firstDay;

else

$firstDate = strtotime('-'. $firstDayOfWeek .' day', $firstDay);

//日历的最后一个日期

if($lastDayOfWeek == 6)

$lastDate = $lastDay;

elseif($lastDayOfWeek == 7)

$lastDate = strtotime('+6 day', $lastDay);

else

$lastDate = strtotime('+'.(6-$lastDayOfWeek).' day', $lastDay);

return array(

'days' => $days,

'firstDayOfWeek' => $firstDayOfWeek,

'lastDayOfWeek' => $lastDayOfWeek,

'lastMonthOfLastDay' => $lastMonthOfLastDay,

'firstDate' => $firstDate,

'lastDate' => $lastDate,

'year' => $year,

'month' => $month

);

}

2、caculate方法,计算日历的天数与样式

1)将上个月的天数计算出来,本月第一天的星期不是星期天的话,就需要根据上个月的最后一天计算

2)将本月的天数遍历出来,如果是休息天就加上特殊的css样式

3)将下个月的天数计算出来,分三种情况,星期日、星期六和工作日

/**

* @author Pwstrick

* @param array $calendar 通过threshold方法计算后的数据

* @deprecated 计算日历的天数与样式

*/

function caculate($calendar) {

$days = $calendar['days'];

$firstDayOfWeek = $calendar['firstDayOfWeek'];//本月第一天的星期

$lastDayOfWeek = $calendar['lastDayOfWeek'];//本月最后一天的星期

$lastMonthOfLastDay = $calendar['lastMonthOfLastDay'];//上个月的最后一天

$year = $calendar['year'];

$month = $calendar['month'];

$dates = array();

if($firstDayOfWeek != 7) {

$lastDays = array();

$current = $lastMonthOfLastDay;//上个月的最后一天

for ($i = 0; $i < $firstDayOfWeek; $i++) {

array_push($lastDays, $current);//添加上一个月的日期天数

$current--;

}

$lastDays = array_reverse($lastDays);//反序

foreach ($lastDays as $index => $day) {

array_push($dates, array('day' => $day, 'tdclass' => ($index ==0 ?'rest':''), 'pclass' => 'outter'));

}

}

//本月日历信息

for ($i = 1; $i <= $days; $i++) {

$isRest = $this->_checkIsRest($year, $month, $i);

//判断是否是休息天

array_push($dates, array('day' => $i, 'tdclass' => ($isRest ?'rest':''), 'pclass' => ''));

}

//下月日历信息

if($lastDayOfWeek == 7) {//最后一天是星期日

$length = 6;

}

elseif($lastDayOfWeek == 6) {//最后一天是星期六

$length = 0;

}else {

$length = 6 - $lastDayOfWeek;

}

for ($i = 1; $i <= $length; $i++) {

array_push($dates, array('day' => $i, 'tdclass' => ($i==$length ?'rest':''), 'pclass' => 'outter'));

}

return $dates;

}

3、draw方法,画表格,设置table中的tr与td

1)数据将要用table标签来显示,所以这里要将各个tr下面的td排列好

2)$index % 7 == 0 计算表格每行的第一列

3)$index % 7 == 6 || $index == ($length-1) 计算每行的最后一列,或$caculate的最后一个数据

4)将中间行添加到$tr中,就是每一行的array

/**

* @author Pwstrick

* @param array $caculate 通过caculate方法计算后的数据

* @deprecated 画表格,设置table中的tr与td

*/

function draw($caculate) {

$tr = array();

$length = count($caculate);

$result = array();

foreach ($caculate as $index => $date) {

if($index % 7 == 0) {//第一列

$tr = array($date);

}elseif($index % 7 == 6 || $index == ($length-1)) {

array_push($tr, $date);

array_push($result, $tr);//添加到返回的数据中

$tr = array();//清空数组列表

}else {

array_push($tr, $date);

}

}

return $result;

}

通过本文大家应该知道日历制作的方法了,那就趁热打铁,做一个属于自己日历。

php制作万年历的步骤_教大家制作简单的php日历相关推荐

  1. php制作万年历的步骤_使用PHP制作一个万年历

    主要运用date函数和mktime函数 完成结果如下: 代码如下: header("Content-type:text/html;charset=utf-8"); $year = ...

  2. php制作万年历的步骤_时间的宠儿,时尚的经典,它是经久不衰的万年历手表

    ​今年几枚万年历新款相当不错,不妨考虑加入万年历一族. 江诗丹顿 Traditionnelle Twin Beat Perpetual Calendar ​说万年历腕表,没可能不提今年江诗丹顿这枚会变 ...

  3. php制作万年历的步骤_制作一个php万年历

    /** * 1.获取日期年和月,默认当前年份和月份 * 2.计算当前月份有多少天和本月1号是星期几 * 3.输出日期的头部信息 * 4.循环遍历输出输出天数 * 5.完成上一月和下一月链接 * * * ...

  4. php制作万年历的步骤_PHP制作万年历

    本文主要介绍了使用PHP制作万年历的方法以及实现此功能的几个要点并提供了全部源代码,这里推荐给小伙伴们 使用PHP实现万年历功能的要点: 得到当前要处理的月份总共有多少天$days 得到当前要处理的月 ...

  5. 计算机课件制作教程ppt,电脑制作ppt详细步骤_新手制作ppt详细步骤图文教程

    ppt大家应该都不陌生了,我们日常办公时经常会需要制作ppt.可是对于新手来说,还不太清楚电脑制作ppt详细步骤.那么今天小编就为大家带来新手制作ppt详细步骤图文教程,一起来看看吧. 新手制作ppt ...

  6. 如何制作毕业地图分布图_教你做一幅完美的【同学分布图】

    每个夏季似乎都是离别季,班级同学拿着录取通知书纷纷奔向全国各地,怎样在一张地图上展现班级同学在全国各地的分布状况呢?如何制作一副蹭饭地图?如何把同学分布情况做成同学录展示在地图上?谭老师地理工作室综合 ...

  7. 用计算机做图画ppt,电脑制作ppt详细步骤_新手制作ppt详细步骤图文教程

    ppt大家应该都不陌生了,我们日常办公时经常会需要制作ppt.可是对于新手来说,还不太清楚电脑制作ppt详细步骤.那么今天小编就为大家带来新手制作ppt详细步骤图文教程,一起来看看吧. 新手制作ppt ...

  8. html5 video如何添加进度条_教你制作独一无二的进度条视频效果

    VLOG开头经常都会看到进度条,爱心/星星/emoji表情都可以做成进度加载的效果.这究竟是怎么做出来的呢?今天喵酱为大家带来3种方法,轻松制作进度条效果.认真地一步一步查看,保证你也能学会!先来看看 ...

  9. 恢复系统设置或计算机无法点击进入,系统还原步骤_教您系统还原操作方法

    电脑有时出现一些问题时需要还原系统,有些用户知道电脑有还原系统的功能但是不知道具体的还原步骤,小编现在给大家简单说说详细的系统还原步骤. 现在的通信设备等非常的先进,很多的东西都可以在手机上完成,但是 ...

最新文章

  1. ASP.NET(C#)常用数据加密和解密方法汇总
  2. VTK:PolyData之PointCellIds
  3. 如何将Emacs添加到右键菜单并显示为“烤肉”
  4. linux的centos 怎么安装bzip2
  5. SQL注入漏洞与参数化查询
  6. python时间处理,datetime中的strftime/strptime
  7. 西电计科院Python程序设计随课笔记(李光夏)
  8. MSDN我告诉你 一个没有人注意的工具站
  9. uniapp 启动页视频
  10. VTCP QIO技术解析
  11. @linux安装及使用(压缩|解压)工具RAR
  12. Unity 编辑器开发实战【Custom Editor】- FSM Editor
  13. 【Shell编程】几个小案例
  14. OpenGL十二讲代码
  15. 〖Python 数据库开发实战 - Redis篇⑫〗- Redis的事务特性
  16. Android中读values/xml arrays attrs colors dimens string styles
  17. Neo4j Desktop版本的安装学习
  18. 北京证监局责令贾跃亭月底前回国;中移动完成公司制改制;全国首张微信身份证签发丨价值早报
  19. 为什么要做社交电商系统,社交电商系统有哪些模式?
  20. 体验QQ2009 Beta1(多图)

热门文章

  1. mysql 5.5 安装 linux,linux下mysql5.5的安装
  2. Python Tkinter实现一个听书神器
  3. Python小游戏——扫雷
  4. 人工智能城市和智慧城市_智慧城市:人工智能在城市管理中的应用
  5. python画波浪线_matplotlib中的锯齿形或波浪线
  6. Latex参考文献在文中引用格式为author et al. [number]
  7. sublime Emmet的用法及相关语法
  8. UTC-to-CST
  9. 8 RRC Timer、Counters 、Constants(定时器、计数器、常量)
  10. ssm+JSP计算机毕业设计基于ssm的校园求职招聘系统z53y6【源码、程序、数据库、部署】