Heim >PHP-Framework >Denken Sie an PHP >Verstehen Sie __construct() und __initialize() in thinkphp
Über das Verständnis von __construct() und _initialize() in thinkphp
Es gibt viele Meinungen und Verwendungen im Internet, ich habe es getestet Lassen Sie uns einen Blick darauf werfen. Das Folgende ist eine Schlussfolgerung, die auf den Testergebnissen und Ihrem eigenen Verständnis basiert. Wenn etwas nicht stimmt, können Sie es gerne korrigieren. ! !
Werfen wir zunächst einen Blick auf den Inhalt der Controlle-Klasse, die mit Thinkphp geliefert wird (ThinkPHPLibraryThinkController.class.php)
Sehen Sie sich den Konstruktor an:
/** * 架构函数 取得模板对象实例 * @access public */ public function __construct() { Hook::listen('action_begin',$this->config); //实例化视图类 $this->view = Think::instance('Think\View'); //控制器初始化 if(method_exists($this,'_initialize')) $this->_initialize(); }
Vom Konstruktor Wie Sie wissen, bestimmt der Konstruktor in der Controller-Klasse, ob im Objekt eine _initialize-Methode vorhanden ist. Wenn ja, wird die _initialize-Methode zuerst ausgeführt Controller, den wir definieren,
<?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 */②: Der Konstruktor der übergeordneten Klasse ist nicht im überschriebenen Konstrukt implementiert. Wenn die Methode ausgeführt wird, hat die definierte Methode _initialize() keine Auswirkung (die Methode _initialize wird nicht zuerst ausgeführt, wenn die (Methode wird ausgeführt). Schauen Sie sich den Code an:
<?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 */Hinweis: Die hier erwähnte _initialize()-Methode bedeutet, dass es keinen Funktionsaufruf vor parent::__construct(); gibt. :__construct(); self::b(), es ist nicht nötig zu sagen, dass b() zuerst ausgeführt werden muss, aber es wird im Allgemeinen nicht auf diese Weise geschrieben. Es gibt im Allgemeinen keine Ausgabe und Konfiguration vor dem Konstruktor der übergeordneten Klasse ist implementiert Wenn es sich außerdem um Vererbung handelt und die übergeordnete Klasse einen Konstruktor hat, initialisiert die Unterklasse normalerweise zuerst den Konstruktor der übergeordneten Klasse in ihrem Konstruktor, um die Originalität und Integrität des Codes sicherzustellen 2) Es gibt kein Überschreiben des Konstruktors, wenn der Konstruktor nicht in dem von uns definierten Controller deklariert ist und die Methode _initialize() im Controller definiert ist. Wenn wir andere Methoden aufrufen, wird _initialize als erste () Methode aufgerufen, siehe Code:
<?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 */Darüber hinaus kann _initialize() auch zum Erben von
<?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 */verwendet werden. Hinweis: Falls vorhanden kein parent::construct() im Konstruktor der übergeordneten Klasse, das definierte _initialize() funktioniert auch nicht Es gibt also beide __construct() (dieser Konstruktor initialisiert den Konstruktor der übergeordneten Klasse) und _initialize(), welches wird zuerst ausgeführt? Die Antwort lautet: Führen Sie zuerst die Methode _initialize() aus. Das heißt, wenn die Bedingungen erfüllt sind, muss die Funktion _initialize() ausgeführt werden, bevor eine Methode ausgeführt wird, einschließlich des Konstruktors
Wenn Sie in der auszuführenden Methode eine andere oder mehrere Methoden aufrufen und diese Methoden zusätzlich aufrufen, wird die Methode _initialize() natürlich nicht erneut ausgeführt, sondern ist mit der Methode verknüpft, die Sie als erste aufgerufen haben Zeit, das heißt, es hat keine Kontrolle darüber, was in der Methode getan wird. Empfohlenes Tutorial: „
thinkphp-Framework
“Das obige ist der detaillierte Inhalt vonVerstehen Sie __construct() und __initialize() in thinkphp. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!