PHP实现简单日历类编写


Posted in PHP onAugust 28, 2020

用PHP实现日历类的编写,供大家参考,具体内容如下

calendar.class.php

<?php
/*
* 创建一个日历类
*
*
*/
 //修改默认时区
 date_default_timezone_set("PRC");
 
 class Calendar {
  private $year;
 private $month;
 private $day; //当月总天数
 private $first_week; //每月的第一天是星期几
 
 //构造函数
 function __construct() {
  $this->year = isset($_GET['year'])?$_GET['year']:date("Y");
  $this->month = isset($_GET["month"])?$_GET["month"]:date("m");
  $this->first_week = date("w", mktime(0, 0 ,0, $this->month, 1, $this->year));
  $this->day = date("t", mktime(0, 0 ,0, $this->month, 1, $this->year));
 }
 function showCalendar() {
 //  echo $this->year."年".$this->month."月".$this->first_week."天".$this->day;
   echo "<table align='center'>"; //用表格输出
   $this->chageDate("index.php"); //用于用户调整年月份
  $this->weekList();//显示星期
  $this->dayList(); //显示天数
  
  echo "</table>";
 }
 //1、显示星期
 private function weekList() {
  $week = array("日","一","二","三","四","五","六");
  echo "<tr>";
   for ($i = 0; $i < count($week); $i++) {
   echo "<th>".$week[$i]."</th>";
  }
  echo "</tr>";
 }
 //2.显示天数
 private function dayList() {
  $color = "#2ca50c";
  echo "<tr>";
  for ($i = 0; $i < $this->first_week; $i++) { //输出空格,弥补当前月空缺部分
   echo "<td bgcolor='#2ca50c'> </td>";
  }
  for ($k = 1; $i <= $this->day; $k++) {
   $i++;
   if ($k == date("d")) echo "<td id='nowd'>".$k."</td>"; //是今天,加效果
   else echo "<td bgcolor=$color>".$k."</td>";
   if ($i % 7 == 0) {
   echo "</tr><tr>"; //每7天一次换行
   if ($i % 2 == 0) $color = "#2ca50c";
   else $color = "#9ddb27"; //实现各行换色的效果
   }
  }
  while ($i % 7 != 0) { //将剩余的空格补完
   echo "<td bgcolor='#2ca50c'> </td>";
  $i++; 
  }
  echo "</tr>";
 }
  
 //3、用于用户调整天数
 private function chageDate($url="index.php") {
  echo "<tr>";
   echo "<caption><h1>".$this->year."年".$this->month."月</h1></caption>"; 
  echo "</tr>";
  echo "<tr>";
  echo "<td>"."<a href='?".$this->prevYear($this->year,$this->month)."'>"."<"."</a>";
  echo "<td>"."<a href='?".$this->prevMonth($this->year,$this->month)."'>"."<<"."</a>";
  
  echo "<td colspan='3'>";
   echo '<select οnchange="window.location=\''.$url.'?year=\'+this.options[selectedIndex].value+\'&month='.$this->month.'\'">';
    for ($year = 2038; $year >= 1970; $year--) {
    $selected = ($year == $this->year)?"selected":"";
    echo '<option '.$selected. ' value="'.$year.'">'.$year.'</option>';
    //echo '<option '.$selected.' value="'.$year.'">'.$year.'</option>';
   }
   echo "</select>";
   
  echo '<select name="month" οnchange="window.location=\''.$url.'?year='.$this->year.'&month=\'+this.options[selectedIndex].value">';
  for($month=1;$month <= 12;$month++){
   $selected1 = ($month == $this->month) ? "selected" : "";
   echo '<option '.$selected1.' value="'.$month.'">'.$month.'</option>';
  }
  echo '</select>';
  echo "</td>";
  
  
  echo "<td>"."<a href='?".$this->nextMonth($this->year,$this->month)."'>".">>"."</a>";
  echo "<td>"."<a href='?".$this->nextYear($this->year,$this->month)."'>".">"."</a>";
  echo "</tr>";
 }
 
 private function prevYear($year, $month) { //获取上一年的数据
  $year--;
  if ($year < 1970) $year = 1970;
  return "year={$year}&month={$month}";
 }
 private function prevMonth($year, $month) {
  if ($month == 1) {
   $year--;
  if ($year < 1970) $year = 1970;
  $month = 12;
  }else $month--; 
  return "year={$year}&month={$month}";
 }
 private function nextYear($year, $month) { //获取上一年的数据
  $year++;
  if ($year > 2038) $year = 2038;
  return "year={$year}&month={$month}";
 }
 private function nextMonth($year, $month) {
  if ($month == 12) {
   $year++;
  if ($year > 2038) $year = 2038;
  $month = 1;
  }else $month++; 
  return "year={$year}&month={$month}";
 }
 }

主页 index.php

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>日历显示</title>
<style>
 table {
 border:1px solid #050;
 margin: 100px auto;
 }
 th {
  width: 30px;
 background-color: #0CC;
 color: #fff;
 height: 30px;
 font-size: 20px;
 }
 #nowd {
  color: yellow;
 background: #F00;
 }
 td {
  width: 30px;
 text-align: center;
 
 height: 25px;
 color: #fff;
 }
 a {
 display: block;
 width: 35px;
 height: 35px;
 background: #0F9;
  text-decoration: none;
 text-align: center;
 line-height: 35px;
 }
 a:hover {
  background: #CF0;
 color: #fff;
 font-size: 20px;
 }
</style>
</head>
 
<body>
 <?php
 include "calendar.class.php";
 $ca = new Calendar();
 $ca->showCalendar();
 ?>
</body>
</html>

PHP实现简单日历类编写

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
简单的过滤字符串中的HTML标记
Dec 25 PHP
php连接数据库代码应用分析
May 29 PHP
PHP内核探索:变量概述
Jan 30 PHP
php统计时间和内存使用情况示例分享
Mar 13 PHP
PHP中实现Bloom Filter算法
Mar 30 PHP
帝国cms常用标签汇总
Jul 06 PHP
php微信高级接口群发 多客服
Jun 23 PHP
[原创]php简单防盗链验证实现方法
Jul 09 PHP
Yii 2.0自带的验证码使用经验分享
Jun 19 PHP
php 猴子摘桃的算法
Jun 20 PHP
PHP实现的ID混淆算法类与用法示例
Aug 10 PHP
Laravel5.7 Eloquent ORM快速入门详解
Apr 12 PHP
PHP实现文件上传与下载
Aug 28 #PHP
PHP实现计算器小功能
Aug 28 #PHP
PHP实现简易图形计算器
Aug 28 #PHP
PHP实现简单的计算器
Aug 28 #PHP
php实现简易计算器
Aug 28 #PHP
有关PHP 中 config.m4 的探索
Aug 26 #PHP
安装PHP扩展时解压官方 tgz 文件后没有configure文件无法进行配置编译的问题
Aug 26 #PHP
You might like
PHPShop存在多个安全漏洞
2006/10/09 PHP
php采集时被封ip的解决方法
2010/08/29 PHP
PHP测试程序运行时间的类
2012/02/05 PHP
PHP实现留言板功能的详细代码
2017/03/25 PHP
Yii2使用表单上传文件的实例代码
2017/08/03 PHP
网页中CDATA标记的说明
2010/09/12 Javascript
深入理解JavaScript定时机制
2010/10/29 Javascript
Extjs中ComboBoxTree实现的下拉框树效果(自写)
2013/05/28 Javascript
JS正则验证邮箱的格式详细介绍
2013/11/19 Javascript
使用node.js 获取客户端信息代码分享
2014/11/26 Javascript
javascript实现无缝上下滚动特效
2015/12/16 Javascript
关于Vue.js一些问题和思考学习笔记(2)
2016/12/02 Javascript
谈谈JavaScript数组常用方法总结
2017/01/24 Javascript
一个可复用的vue分页组件
2017/05/15 Javascript
nuxt框架中路由鉴权之Koa和Session的用法
2018/05/09 Javascript
通过JS深度判断两个对象字段相同
2019/06/14 Javascript
layui 上传图片 返回图片地址的方法
2019/09/26 Javascript
微信小程序实现音频文件播放进度的实例代码
2020/03/02 Javascript
javascript设计模式 ? 访问者模式原理与用法实例分析
2020/04/26 Javascript
vue基于Echarts的拖拽数据可视化功能实现
2020/12/04 Vue.js
JavaScript中Object、map、weakmap的区别分析
2020/12/15 Javascript
Python实现线程池代码分享
2015/06/21 Python
Python pexpect模块及shell脚本except原理解析
2020/08/03 Python
使用python把xmind转换成excel测试用例的实现代码
2020/10/12 Python
CSS3 box-sizing属性
2009/04/17 HTML / CSS
凯撒娱乐:Caesars Entertainment
2018/02/23 全球购物
员工培训心得体会
2013/12/30 职场文书
事业单位接收函
2014/01/10 职场文书
安全协议书范本
2014/04/21 职场文书
学校法制宣传月活动总结
2014/07/03 职场文书
关于运动会的广播稿
2014/09/22 职场文书
出纳岗位职责范本
2015/03/31 职场文书
2015年组织委员工作总结
2015/04/23 职场文书
2015年留守儿童工作总结
2015/05/22 职场文书
住房公积金贷款工资证明
2015/06/12 职场文书
《战锤40K:暗潮》跳票至9月 公布新宣传片
2022/04/03 其他游戏