thinkphp中__construct()和__initialize()的介紹


關於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()方法是不會再執行了,它關聯的是你首次調用的方法,也就是說,方法里面干什么,它管不着了。

 

更多學習內容請訪問:

騰訊T3-T4標准精品PHP架構師教程目錄大全,只要你看完保證薪資上升一個台階(持續更新)​

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM