Goodmorning everybody!
我不是全新的PHP,就像在自我中一样,但在使用PHP5的OO时仍然是新的。现在,我想到了这个小项目,我想使用HTML5和一些OO PHP。它有一天应该是一个可水平滚动的时间轴。
因此我创建了一个课程时间轴。这是我的主要目标。在其他方法中,一种方法( $ timeline-> createYearString(); )是创建我的年代字符串。我实现了另一个类 Year ,方法 createYearString(); 调用X次,以便创建我年份的HTML输出。
为了填补我的事实,我需要一个数据库连接。作为对mysql连接的oop方法的新手,我搜索并发现了Atli关于mysqli单例的评论(http://www.dreamincode.net/forums/topic/81496-connection-to-the-mysql-using-oop/page__view__findpost__p__1038512)。我实现了它并尝试在类 Year 的对象中使用它。有趣的是,$ dbLink为第一个对象返回,但不是第二个对象,它是按照第一个对象的方式立即创建的。 $ this-> db 在第二年突然返回NULL,因此我从PHP获得了非对象FATAL错误
请参阅下面的三个课程。我错过了什么?
class Year {
private $year;
private $db;
function __construct($year) {
$this->year=$year;
$this->db=MyDB::Get();
}
function createHTML($last='') {
$out=" <div class=\"year_outer".(($last) ? ' last_year' : '')."\" id=\"y".$this->year."\">
<div class=\"year_inner\">
<div class=\"year_above\">
<span class=\"yearnr\">".$this->year."</span>
</div>
<div class=\"year_below\"></div>
</div>
<div class=\"months_wrapper\">\n";
if(!$last) {
for($i=1; $i<=12; $i++) {
$fDoM = mktime(0,0,0,$i,1,$this->year); // $fDoM = first Day of Month
$lDoM = mktime(0,0,0,$i,date('t',mktime(0,0,0,$i,1,$this->year)),$this->year); // $lDoM = last Day of Month
$sql = $this->db->query("SELECT * FROM tp_together");
//echo date('d.m.Y',$fDoM)." bis ".date('d.m.Y',$lDoM)."\n";
$out.= " <div class=\"month_outer_l\" id=\"".$this->year."-".$i."\">
<div class=\"month_outer_s\">
<div class=\"month_inner\"><span>".date("M",mktime(0,0,0,$i,1,$this->year))."</span></div>
</div>
</div>\n";
}
}
$out.= " </div>
</div>\n";
return $out;
}
}
class Timeline {
public $daysDating;
public $startYear;
public $endYear;
public $numberOfYears;
function __construct($start,$end='') {
$this->startYear = $start;
$this->endYear = ($end=='') ? date("Y")+1 : $end;
$this->daysDating = $this->calcDaysDating();
$this->numberOfYears= $this->calcNumberOfYears();
}
function createYearString() {
$x=new Year('2004');
print $x->createHTML();
$y=new Year('2005');
print $y->createHTML();
$z=new Year('2006');
print $z->createHTML(true);
// $j=$this->endYear;
// for($i=$this->startYear; $i<=$j; $i++) {
// $x=new Year($i);
// ($i==$j) ?
// print $x->createHTML(true) :
// print $x->createHTML();
// }
}
private function calcDaysDating() {
$today=mktime(0,0,0,date("m"),date("d"),date("y"));
$day1=mktime(0,0,0,7,11,2006);
return $today-$day1;
}
private function calcNumberOfYears() {
return $this->endYear - $this->startYear +1;
}
function createHNavigation() {
$x=1;
$out='<ul>';
for($i=$this->startYear; $i<=$this->endYear; $i++) {
$out.="<li><a class=\"navBubble\" id=\"navBubble$i\" accesskey=\"$x\" href=\"#y$i\" title=\"Go to $i\"></a></li>\n";
$x++;
}
$out.="</ul>";
return $out;
}
}
class MyDB {
private static $dbLink;
private function __construct() {}
private function __clone() {}
public static function Get() {
if(!self::$dbLink) {
self::$dbLink = new mysqli(DB_HOST, DB_USER, DB_PWD, DB_NAME);
if(mysqli_connect_errno()) {
throw new Exception("Database connection failed: ".mysqli_connect_error());
}
return self::$dbLink;
}
}
}
如果我没有明白我的问题。 $ x类似于2004年($ x =新年('2004')),工作正常。但接下来的$ y($ y = new Year('2005')返回FATAL ERROR而$ this-&gt; db返回NULL - 为什么?
非常感谢,非常感谢您的帮助。
答案 0 :(得分:1)
你的MyDB :: Get函数在已经设置的情况下不会返回self :: $ dbLink。
原文回复:
public static function Get() {
if(!self::$dbLink) {
self::$dbLink = new mysqli(DB_HOST, DB_USER, DB_PWD, DB_NAME);
if(mysqli_connect_errno()) {
throw new Exception("Database connection failed: ".mysqli_connect_error());
}
return self::$dbLink;
}
}
返回以便它起作用:
public static function Get() {
if(!self::$dbLink) {
self::$dbLink = new mysqli(DB_HOST, DB_USER, DB_PWD, DB_NAME);
if(mysqli_connect_errno()) {
throw new Exception("Database connection failed: ".mysqli_connect_error());
}
}
return self::$dbLink;
}
(PS,使用多个单个字符进行缩进会使这更易于检测。)
答案 1 :(得分:1)
public static function Get() {
if(!self::$dbLink) {
self::$dbLink = new mysqli(DB_HOST, DB_USER, DB_PWD, DB_NAME);
if(mysqli_connect_errno()) {
throw new Exception("Database connection failed: ".mysqli_connect_error());
}
//was here
}
return self::$dbLink; //should be here
}