Über das Verständnis von __construct() und _initialize() in thinkphp
Es gibt viele Meinungen und Verwendungen im Internet, die ich selbst getestet habe zum Test Die Ergebnisse werden mit Ihrem eigenen Verständnis kombiniert, um Schlussfolgerungen zu ziehen. Sollten sich Fehler ergeben, können Sie diese 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 in der Controller-Klasse Wie Sie wissen, bestimmt der Konstruktor, ob im Objekt eine _initialize-Methode vorhanden ist. Wenn ja, wird die _initialize-Methode zuerst ausgeführt.
Wenn wir uns also in einem Controller befinden, der durch definiert ist uns selbst,
1): Es gibt einen überschriebenen Konstruktor:
①Im überschriebenen Konstrukt gibt es einen Konstruktor, der die übergeordnete Klasse implementiert (parent::construct()),
Wenn im Controller die Methode _initialize() definiert ist, führen wir beim Aufruf der Methode im Controller zuerst die Methode _initialize() aus und führen dann die Methode aus, die wir benötigen:
<?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 ausgeführt wird 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 erfolgt im Allgemeinen keine Ausgabe und Konfiguration vor dem Konstruktor der übergeordneten Klasse 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, wenn die Methode _initialize() im Controller definiert ist, wenn wir andere aufrufen Methoden: _initialize wird als erste () Methode aufgerufen. Sehen 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 这是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 sowohl __construct() (der Konstruktor initialisiert den Konstruktor der übergeordneten Klasse) als auch _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-Tutorial
Das obige ist der detaillierte Inhalt vonEinführung in __construct() und __initialize() in thinkphp. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!