用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实现的简单日历类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现的简单日历类。分享给大家供大家参考。 具体实现代码如下: 希望本文所述对大家的php程序设计有所帮助。
本文向大家介绍JS实现简单日历特效,包括了JS实现简单日历特效的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JS实现简单日历特效的具体代码,供大家参考,具体内容如下 知识点 1.引入我的工具包 2.运用JavaScript内置对象 Date 运行效果 代码 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍JavaScript实现简单日历效果,包括了JavaScript实现简单日历效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JavaScript实现简单日历效果的具体代码,供大家参考,具体内容如下 实现效果: 根据所选择的年月,列出当月对应是周几,效果图如下: 实现思路: 1、使用select标签保存年月的所选菜单。使用table标签保存当月天数,表头为固定的周日周
本文向大家介绍js编写当天简单日历效果【实现代码】,包括了js编写当天简单日历效果【实现代码】的使用技巧和注意事项,需要的朋友参考一下 之前一直很想用javascript写一个日历,但是因为完全没有好的思路, 所以迟迟没有尝试。最近在网上刚好看到用javascript编写的简单日历的例子,代码量虽然不大, 但是我觉得很好地阐述了js日历的实现原理。自己也尝试着做了一下,收获蛮大,掌握了基本的实现原
本文向大家介绍jQuery简单实现日历的方法,包括了jQuery简单实现日历的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery简单实现日历的方法。分享给大家供大家参考。具体分析如下: 原理挺简单的,首先算出一个月有多少天,再算出这个月的第一天是星期几,接着顺序排下来就可以了. 希望本文所述对大家的jQuery程序设计有所帮助。
本文向大家介绍vue+elementUI实现简单日历功能,包括了vue+elementUI实现简单日历功能的使用技巧和注意事项,需要的朋友参考一下 vue+elementUI简单的实现日历功能,供大家参考,具体内容如下 ## javascript 完成后的效果 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。