实例来源: PHP基础案例教程
注: 在源代码基础上简单修改了一下,源代码是将当前年份的年历按每行4个月份进行显示。我自己敲得时候出现了一些问题(应该是由于书上没有给出对应的css样式代码导致的)
功能 只显示当前月份的日历,直接调用函数即可显示
【完整代码】
<?php
function calendar()
{
/**
* 获取指定年份的第一天是星期几
*
*/
//在实现日期的输出前,需要获取该年份的第一天是星期几,然后才能将日期输出到对应的位置
$year = date('Y'); //当前年份
$month=date('n'); //当前月份
$day=date('d'); //当前日期
//$w保存了获取到的星期数值,如0表示星期日
$w = date('w', strtotime("{$year}-1-1"));
/**
* 拼接每个月份的表格
*
*/
for ($m = 1; $m <= 4; ++$m) {
//变量$html用于保存字符串拼接的年历HTML生成结果
$html = '';
$html .= '<table>';
$html .= '<tr><th colspan="7" style="background-color: coral;">' . $year . '年' . $m . '月</th></tr>';
$html .= '<tr><td>日</td><td>一</td><td>二</td><td>三</td><td>四</td><td>五</td><td>六</td></tr>';
/**
*遍历指定月份中的每一天
*
*/
//获取当前月份$m有多少天
@$max = date('t', "$year-$m");
//从该月份的第一天循环到最后一天
$html .= '<tr>';
for ($d = 1; $d <= $max; ++$d) {
if ($w && $d == 1) {
//如果该月的第一天不是星期日,则填充空白
$html .= "<td colspan=\"$w\"></td>";
}
if ($day==$d && $month==$m) {
$html .= "<td style='background-color: #FFFF33;'>$d</td>";
} else {
$html .= "<td>$d</td>";
}
//每月的第几天
if ($w == 6 && $d != $max) {
//如果星期六不是该月的最后一天,则换行
$html .= '</tr><tr>';
} elseif ($d == $max) {
//该月的最后一天,闭合<tr>标签
$html .= '</tr>';
}
$w = ($w + 1 > 6) ? 0 : $w + 1;
//控制星期值在0-6范围内变动
}
$html .= '</table>';
$cal[$m]=$html;
}
echo $cal[$month];
}
calendar();
修改后的显示效果,最初的想法是加一个下拉列表,根据下拉选项显示对应的月份,不过感觉有点困难,没做出来,如果哪位大佬做出来了,希望分析以下代码