我使用startutorial
中的免费PHP日历类在private function _showDay($cellNumber)
中,我开发了一个小功能,可以用红色将实际的日期涂成彩色。
if(date("Y-m-d") == $this->currentDate) { $heute = "background-color: red;"; }
return '<li id="li-'.$this->currentDate.'" class="'.($cellNumber%7==1?' start ':($cellNumber%7==0?' end ':' ')).
($cellContent==null?'mask':''). '"style="'. $heute .'">'.$cellContent.'</li>';
这正在工作。
现在,我想将db中的所有条目计数到实际的日期/日期。
我的日历条目的mysql数据库如下:
id | headline | text | timestamp (datum)
我的计数看起来像这样
$offen = "SELECT COUNT(*) AS anzahl
FROM info_info
WHERE `datum` > '2018-09-06 00:00:00' AND `datum` < '2018-09-06 23:59:59'";
$resultoffen = $con->query($offen);
if ($resultoffen->num_rows > 0) {
while($row = $resultoffen->fetch_assoc()) {
$ungelesen = $row["anzahl"];
echo $ungelesen;
}
}
我的完整自定义脚本如下:
<?php
class Calendar {
/**
* Constructor
*/
public function __construct(){
$this->naviHref = htmlentities($_SERVER['PHP_SELF']);
}
/********************* PROPERTY ********************/
private $dayLabels = array("Mo","Di","Mi","Do","Fr","Sa","So");
private $currentYear = 0;
private $currentMonth = 0;
private $currentDay = 0;
private $currentDate = null;
private $daysInMonth = 0;
private $naviHref = null;
/********************* PUBLIC **********************/
/**
* print out the calendar
*/
public function show() {
$year == null;
$month == null;
if(null==$year&&isset($_GET['year'])){
$year = $_GET['year'];
}else if(null==$year){
$year = date("Y",time());
}
if(null==$month&&isset($_GET['month'])){
$month = $_GET['month'];
}else if(null==$month){
$month = date("m",time());
}
$this->currentYear=$year;
$this->currentMonth=$month;
$this->daysInMonth=$this->_daysInMonth($month,$year);
$content='<div id="calendar">'.
'<div class="box">'.
$this->_createNavi().
'</div>'.
'<div class="box-content">'.
'<ul class="label">'.$this->_createLabels().'</ul>';
$content.='<div class="clear"></div>';
$content.='<ul class="dates">';
$weeksInMonth = $this->_weeksInMonth($month,$year);
// Create weeks in a month
for( $i=0; $i<$weeksInMonth; $i++ ){
//Create days in a week
for($j=1;$j<=7;$j++){
$content.=$this->_showDay($i*7+$j);
}
}
$content.='</ul>';
$content.='<div class="clear"></div>';
$content.='</div>';
$content.='</div>';
return $content;
}
/********************* PRIVATE **********************/
/**
* create the li element for ul
*/
private function _showDay($cellNumber){
if($this->currentDay==0){
$firstDayOfTheWeek = date('N',strtotime($this->currentYear.'-'.$this->currentMonth.'-01'));
if(intval($cellNumber) == intval($firstDayOfTheWeek)){
$this->currentDay=1;
}
}
if( ($this->currentDay!=0)&&($this->currentDay<=$this->daysInMonth) ){
$this->currentDate = date('Y-m-d',strtotime($this->currentYear.'-'.$this->currentMonth.'-'.($this->currentDay)));
$cellContent = $this->currentDay;
$this->currentDay++;
}else{
$this->currentDate = null;
$cellContent=null;
}
//aktuellen tag rot markieren
if(date("Y-m-d") == $this->currentDate) { $heute = "background-color: red;"; }
//anzahl der kalendereinträge
$offen = "SELECT COUNT(*) AS anzahl
FROM info_info
WHERE `datum` > '".$this->currentDate." 00:00:00' AND `datum` < '".$this->currentDate." 23:59:59'";
$resultoffen = $con->query($offen);
if ($resultoffen->num_rows > 0) {
while($row = $resultoffen->fetch_assoc()) {
$ungelesen = $row["anzahl"];
echo $ungelesen;
}
}
//gib kalender zurück
return '<li id="li-'.$this->currentDate.'" class="'.($cellNumber%7==1?' start ':($cellNumber%7==0?' end ':' ')).
($cellContent==null?'mask':''). '"style="'. $heute .'">'.$cellContent.'</li>';
}
/**
* create navigation
*/
private function _createNavi(){
$nextMonth = $this->currentMonth==12?1:intval($this->currentMonth)+1;
$nextYear = $this->currentMonth==12?intval($this->currentYear)+1:$this->currentYear;
$preMonth = $this->currentMonth==1?12:intval($this->currentMonth)-1;
$preYear = $this->currentMonth==1?intval($this->currentYear)-1:$this->currentYear;
return
'<div class="header">'.
'<a class="prev" href="'.$this->naviHref.'?month='.sprintf('%02d',$preMonth).'&year='.$preYear.'">Zurück</a>'.
'<span class="title">'.date('m/Y',strtotime($this->currentYear.'-'.$this->currentMonth.'-1')).'</span>'.
'<a class="next" href="'.$this->naviHref.'?month='.sprintf("%02d", $nextMonth).'&year='.$nextYear.'">Nächster</a>'.
'</div>';
}
/**
* create calendar week labels
*/
private function _createLabels(){
$content='';
foreach($this->dayLabels as $index=>$label){
$content.='<li class="'.($label==6?'end title':'start title').' title">'.$label.'</li>';
}
return $content;
}
/**
* calculate number of weeks in a particular month
*/
private function _weeksInMonth($month=null,$year=null){
if( null==($year) ) {
$year = date("Y",time());
}
if(null==($month)) {
$month = date("m",time());
}
// find number of days in this month
$daysInMonths = $this->_daysInMonth($month,$year);
$numOfweeks = ($daysInMonths%7==0?0:1) + intval($daysInMonths/7);
$monthEndingDay= date('N',strtotime($year.'-'.$month.'-'.$daysInMonths));
$monthStartDay = date('N',strtotime($year.'-'.$month.'-01'));
if($monthEndingDay<$monthStartDay){
$numOfweeks++;
}
return $numOfweeks;
}
/**
* calculate number of days in a particular month
*/
private function _daysInMonth($month=null,$year=null){
if(null==($year))
$year = date("Y",time());
if(null==($month))
$month = date("m",time());
return date('t',strtotime($year.'-'.$month.'-01'));
}
}
但是该类未加载。我没有输出。
在php日志文件中看到以下内容:
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: year in C:\inetpub\wwwroot\info\class_calendar.php on line 33
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: month in C:\inetpub\wwwroot\info\class_calendar.php on line 35
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: year in C:\inetpub\wwwroot\info\class_calendar.php on line 37
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: year in C:\inetpub\wwwroot\info\class_calendar.php on line 41
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: month in C:\inetpub\wwwroot\info\class_calendar.php on line 47
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: month in C:\inetpub\wwwroot\info\class_calendar.php on line 51
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Notice: Undefined variable: con in C:\inetpub\wwwroot\info\class_calendar.php on line 136
[13-Sep-2018 09:59:15 Europe/Berlin] PHP Fatal error: Uncaught Error: Call to a member function query() on null in C:\inetpub\wwwroot\info\class_calendar.php:136
Stack trace:
#0 C:\inetpub\wwwroot\info\class_calendar.php(78): Calendar->_showDay(1)
#1 C:\inetpub\wwwroot\info\calendar.php(47): Calendar->show()
#2 {main}
thrown in C:\inetpub\wwwroot\info\class_calendar.php on line 136
怎么了?
答案 0 :(得分:0)
我知道了。这是我的自定义代码:
<?php
/**
*@author Xu Ding
*@email thedilab@gmail.com
*@website http://www.StarTutorial.com
**/
class Calendar {
/**
* Constructor
*/
public function __construct(){
$this->naviHref = htmlentities($_SERVER['PHP_SELF']);
$this->con = new mysqli("localhost","XXXX","XXXX","XXXX");
}
/********************* PROPERTY ********************/
private $dayLabels = array("Mo","Di","Mi","Do","Fr","Sa","So");
private $currentYear = 0;
private $currentMonth = 0;
private $currentDay = 0;
private $currentDate = null;
private $daysInMonth = 0;
private $naviHref = null;
/********************* PUBLIC **********************/
/**
* print out the calendar
*/
public function show() {
$year == null;
$month == null;
if(null==$year&&isset($_GET['year'])){
$year = $_GET['year'];
}else if(null==$year){
$year = date("Y",time());
}
if(null==$month&&isset($_GET['month'])){
$month = $_GET['month'];
}else if(null==$month){
$month = date("m",time());
}
$this->currentYear=$year;
$this->currentMonth=$month;
$this->daysInMonth=$this->_daysInMonth($month,$year);
$content='<div id="calendar">'.
'<div class="box">'.
$this->_createNavi().
'</div>'.
'<div class="box-content">'.
'<ul class="label">'.$this->_createLabels().'</ul>';
$content.='<div class="clear"></div>';
$content.='<ul class="dates">';
$weeksInMonth = $this->_weeksInMonth($month,$year);
// Create weeks in a month
for( $i=0; $i<$weeksInMonth; $i++ ){
//Create days in a week
for($j=1;$j<=7;$j++){
$content.=$this->_showDay($i*7+$j);
}
}
$content.='</ul>';
$content.='<div class="clear"></div>';
$content.='</div>';
$content.='</div>';
return $content;
}
/********************* PRIVATE **********************/
/**
* create the li element for ul
*/
private function _showDay($cellNumber){
if($this->currentDay==0){
$firstDayOfTheWeek = date('N',strtotime($this->currentYear.'-'.$this->currentMonth.'-01'));
if(intval($cellNumber) == intval($firstDayOfTheWeek)){
$this->currentDay=1;
}
}
if( ($this->currentDay!=0)&&($this->currentDay<=$this->daysInMonth) ){
$this->currentDate = date('Y-m-d',strtotime($this->currentYear.'-'.$this->currentMonth.'-'.($this->currentDay)));
$cellContent = $this->currentDay;
$this->currentDay++;
}else{
$this->currentDate = null;
$cellContent=null;
}
//aktuellen tag rot markieren
if(date("Y-m-d") == $this->currentDate) { $heute = "background-color: red;"; }
//anzahl der kalendereinträge
$offen = "SELECT COUNT(*) AS anzahl
FROM info_info
WHERE `datum` > '".$this->currentDate." 00:00:00' AND `datum` < '".$this->currentDate." 23:59:59'";
$resultoffen = $this->con->query($offen);
if ($resultoffen->num_rows > 0) {
while($row = $resultoffen->fetch_assoc()) {
//$ungelesen = $row["anzahl"];
if ($row["anzahl"] == "0") {
$ungelesen = "";
}
else {
//$ungelesen = $row['anzahl'];
$eintrag = "background-color: green;";
}
}
}
//gib kalender zurück
return '<li id="li-'.$this->currentDate.'" class="'.($cellNumber%7==1?' start ':($cellNumber%7==0?' end ':' ')).
($cellContent==null?'mask':''). ' "style="'.$heute.$eintrag.'">'.$cellContent.$ungelesen.'</li>';
}
/**
* create navigation
*/
private function _createNavi(){
$nextMonth = $this->currentMonth==12?1:intval($this->currentMonth)+1;
$nextYear = $this->currentMonth==12?intval($this->currentYear)+1:$this->currentYear;
$preMonth = $this->currentMonth==1?12:intval($this->currentMonth)-1;
$preYear = $this->currentMonth==1?intval($this->currentYear)-1:$this->currentYear;
return
'<div class="header">'.
'<a class="prev" href="'.$this->naviHref.'?month='.sprintf('%02d',$preMonth).'&year='.$preYear.'">Zurück</a>'.
'<span class="title">'.date('m/Y',strtotime($this->currentYear.'-'.$this->currentMonth.'-1')).'</span>'.
'<a class="next" href="'.$this->naviHref.'?month='.sprintf("%02d", $nextMonth).'&year='.$nextYear.'">Nächster</a>'.
'</div>';
}
/**
* create calendar week labels
*/
private function _createLabels(){
$content='';
foreach($this->dayLabels as $index=>$label){
$content.='<li class="'.($label==6?'end title':'start title').' title">'.$label.'</li>';
}
return $content;
}
/**
* calculate number of weeks in a particular month
*/
private function _weeksInMonth($month=null,$year=null){
if( null==($year) ) {
$year = date("Y",time());
}
if(null==($month)) {
$month = date("m",time());
}
// find number of days in this month
$daysInMonths = $this->_daysInMonth($month,$year);
$numOfweeks = ($daysInMonths%7==0?0:1) + intval($daysInMonths/7);
$monthEndingDay= date('N',strtotime($year.'-'.$month.'-'.$daysInMonths));
$monthStartDay = date('N',strtotime($year.'-'.$month.'-01'));
if($monthEndingDay<$monthStartDay){
$numOfweeks++;
}
return $numOfweeks;
}
/**
* calculate number of days in a particular month
*/
private function _daysInMonth($month=null,$year=null){
if(null==($year))
$year = date("Y",time());
if(null==($month))
$month = date("m",time());
return date('t',strtotime($year.'-'.$month.'-01'));
}
}