本文實例分析了ThinkPHP中的__initialize()和類的構造函數__construct()。分享給大家供大家參考。具體分析如下:
thinkphp中的__construct是不可以隨便用的,因為你的模塊類繼承上級類,上級類有定義好的;
1、__initialize()不是php類中的函數,php類的構造函數只有__construct().
2、類的初始化:子類如果有自己的構造函數(__construct()),則調用自己的進行初始化,如果沒有,則調用父類的構造函數進行自己的初始化。
3、當子類和父類都有__construct()函數的時候,如果要在初始化子類的時候同時調用父類的__constrcut(),則可以在子類中使用parent::__construct().
如果我們寫兩個類,如下:
復制代碼 代碼如下:class Action{
public function __construct()
{
echo 'hello Action';
}
}
class IndexAction extends Action{
public function __construct()
{
echo 'hello IndexAction';
}
}
$test = new IndexAction;
//output --- hello IndexAction
很明顯初始化子類IndexAction的時候會調用自己的構造器,所以輸出是'hello IndexAction',但是將子類修改為:
復制代碼 代碼如下:class IndexAction extends Action{
public function __initialize()
{
echo 'hello IndexAction';
}
}
那麼輸出的是'hello Action',因為子類IndexAction沒有自己的構造器,如果我想在初始化子類的時候,同時調用父類的構造器呢?
復制代碼 代碼如下:class IndexAction extends Action{
public function __construct()
{
parent::__construct();
echo 'hello IndexAction';
}
}
這樣就可以將兩句話同時輸出,當然還有一種辦法就是在父類中調用子類的方法.
復制代碼 代碼如下:class Action{
public function __construct()
{
if(method_exists($this,'hello'))
{
$this -> hello();
}
echo 'hello Action';
}
}
class IndexAction extends Action{
public function hello()
{
echo 'hello IndexAction';
}
}
這樣也可以將兩句話同時輸出,而這裡子類中的方法hello()就類似於ThinkPHP中__initialize()。
所以,ThinkPHP中的__initialize()的出現只是方便程序員在寫子類的時候避免頻繁的使用parent::__construct(),同時正確的調用框架內父類的構造器,所以,我們在ThnikPHP中初始化子類的時候要用__initialize(),而不用__construct(),當然你也可以通過修改框架將__initialize()函數修改為你喜歡的函數名.
希望本文所述對大家的ThinkPHP框架程序設計有所幫助。