ホームページ >バックエンド開発 >PHPチュートリアル >PHPでのブログカレンダーの実装コード
PHP でのブログ カレンダーの実装コードを共有します。その中には、データベースと同じになるようにフィールド名を変更する限り、データベースへのクエリは非常に簡単であるという文があります。コード例は次のとおりです。 Calendarnew($starttime = 0) {
グローバル $db, $tablepre, $timestamp, $site_timeoffset, $site_dateformat, $curtime
$starttime = $starttime ?
$; curtime = gmdate($site_dateform at, $ starttime + $timeoffset * 3600);
$pendtime = $starttime - (gmdate('j', $starttime + $timeoffset * 3600) - 1) * 86400 - ($ starttime + $timeoffset * 3600) % 86400 ;
$pstarttime = $pendtime - gmdate('t', $pendtime + $timeoffset * 3600 - 1) * 86400;
$nstarttime = $pendtime + gmdate ('t', $pendtime + $timeoffset * 3600 + 1) * 86400;
$nstarttime = $nstarttime + gmdate('t', $nstarttime + $timeoffset * 3600 + 1) * 86400;スキップ, $dim) =explode(' -', gmdate('w-t', $pendtime + $timeoffset * 3600 + 1));
$rows = ceil(($skip + $dim) / 7 );
$blogs = array( );
$query = $db->query("SELECT dateline FROM {$tablepre}vitaitems WHERE dateline BETWEEN '$pendtime' AND '$nstarttime'");
while($blog = $ db->fetch_array($query)) { $day = gmdate('j', $blog['dateline'] + $timeoffset * 3600);!isset($blogs[$day ]) ? $blogs[$day] = array('num' => 1, 'dateline' => $blog['dateline'] - $blog['dateline'] % 86400) : $blogs[$day ]['num']++;
}
$cal = ''; $row
$cal .= '
for($col = 0; $col
$cur = $row * 7 + $skip + 1 ;
$curtd = $row * 7 + $cur > : $cur; $blogs[$cur])) {
$cal .= '
} else {
$cal .= '
}
}
$cal を返す