關於thinkphp中的__construct()和_initialize()的理解
網路上有很多的說法和用法,自己測試了一下,以下是根據測試結果並結合自己的理解得出的結論,如有不對的地方,歡迎大家糾正! ! !
我們先來看看Thinkphp自帶的Controlle類別的內容(ThinkPHP\Library\Think\Controller.class.php)
看看建構子:
/** * 架构函数 取得模板对象实例 * @access public */ public function __construct() { Hook::listen('action_begin',$this->config); //实例化视图类 $this->view = Think::instance('Think\View'); //控制器初始化 if(method_exists($this,'_initialize')) $this->_initialize(); }
從Controller類別中的建構函式中可以知道,建構函式會判斷物件中是否有_initialize方法,如果有,就執行先_initialize方法,
因此,如果我們在自己定義的控制器中,
1):有重寫建構子:
①在重寫的建構子中有實作父類別的建構子(parent::construct() ),
如果該控制器中有定義_initialize()方法,那麼,我們在呼叫該控制器中的方法時,會先執行_initialize()方法,然後再執行我們需要的方法,看程式碼:
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function __construct() { parent::__construct(); self::b(); echo '我是构造<br />'; } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: 我先来 bbbb 我是构造 bbbb 这是index */
②:在重寫的建構中沒有實作父類別的建構函數,執行方法時,定義的_initialize()方法則沒有作用(不會在執行方法時,先執行_initialize方法),看程式碼:
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function __construct() { // parent::__construct(); self::b(); echo '我是构造<br />'; } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: bbbb 我是构造 bbbb 这是index */
註:這裡面的所說的先執行_initialize()方法,是在parent::__construct();前沒有任何函數調用,如果你非得在parent:: __construct();前來個self::b(),那沒得說,肯定是先執行b(),不過一般不這樣寫,在實現父類的構造函數前一般沒有任何輸出和配置
再有,如果是繼承,如果父類別有建構函數,子類別在其建構函數一般先把父類別的建構子先初始化,確保程式碼的原始性和完整性
2)沒有重寫建構函數,也就是說在我們定義的控制器中沒有宣告建構子
這種情況,如果在控制器中有定義_initialize()方法,則當我們呼叫其他方法時,會先呼叫_initialize()方法,看程式碼:
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { // public function __construct() { // // parent::__construct(); // self::b(); // echo '我是构造<br />'; // } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: 我先来 bbbb 这是index */
另外,_initialize()還可以用來繼承
<?php namespace Home\Controller; use Think\Controller; class BaseController extends Controller { public function __construct() { parent::__construct(); echo '我是父类<br />'; } public function _initialize() { echo '我先来<br />'; } public function a() { echo 'aaaa<br />'; } }
<?php namespace Home\Controller; use Think\Controller; class IndexController extends BaseController { public function __construct() { parent::__construct(); self::b(); echo '我是构造<br />'; } public function _initialize() { parent::_initialize(); echo '我是子类先来<br />'; } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: 我先来 我是子类先来 我是父类 bbbb 我是构造 bbbb 这是index */
注意:如果父類別的建構子中沒有parent:: construct(),定義的_initialize()也不起作用
那麼,同時存在__construct()(該建構函式初始化了父類別的建構子)和_initialize() ,到底先執行哪個呢?
答案是-先執行_initialize()方法,也就是說,在滿足條件下,_initialize()函數是在任何方法執行之前,都要執行的,包括建構函數,
當然,如果你在要執行的方法中又呼叫的另一個或多個方法,在另外呼叫那些方法時,_initialize()方法是不會再執行了,它關聯的是你第一次呼叫的方法,也就是說,方法裡面幹什麼,它管不著了。
推薦教學:《thinkphp框架》
以上是理解thinkphp中的__construct()和__initialize()的詳細內容。更多資訊請關注PHP中文網其他相關文章!