Thinkphp框架中,如何区分__construct()和__initialize()方法的作用?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1614个文字,预计阅读时间需要7分钟。
关于ThinkPHP中的`__construct()`和`initialize()`的理解:
在ThinkPHP框架中,`__construct()`和`initialize()`是两个重要的方法,用于在模型或控制器初始化时执行代码。
1. `__construct()`方法: - 这是PHP的构造函数,每当创建一个类的实例时,都会自动调用。 - 通常用于初始化实例变量,如设置模型的基本属性或加载必要的配置。 - 不应该在这里执行数据库查询或复杂逻辑,因为它会在对象创建的早期调用。
2. `initialize()`方法: - ThinkPHP特有的方法,用于在控制器或模型实例化后进行初始化。 - 可以在这里加载模型、执行数据库查询、设置视图变量等。 - 相比`__construct()`,`initialize()`更适合执行业务逻辑和初始化操作。
以下是基于测试结果和个人理解得出的结论:
- `__construct()`主要用于实例化时的基本配置,而`initialize()`则用于加载模型、配置等。- 在实际使用中,`__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()方法是不会再执行了,它关联的是你首次调用的方法,也就是说,方法里面干什么,它管不着了。
推荐教程:thinkphp教程
以上就是thinkphp中__construct()和__initialize()的介绍的详细内容,更多请关注自由互联其它相关文章!
本文共计1614个文字,预计阅读时间需要7分钟。
关于ThinkPHP中的`__construct()`和`initialize()`的理解:
在ThinkPHP框架中,`__construct()`和`initialize()`是两个重要的方法,用于在模型或控制器初始化时执行代码。
1. `__construct()`方法: - 这是PHP的构造函数,每当创建一个类的实例时,都会自动调用。 - 通常用于初始化实例变量,如设置模型的基本属性或加载必要的配置。 - 不应该在这里执行数据库查询或复杂逻辑,因为它会在对象创建的早期调用。
2. `initialize()`方法: - ThinkPHP特有的方法,用于在控制器或模型实例化后进行初始化。 - 可以在这里加载模型、执行数据库查询、设置视图变量等。 - 相比`__construct()`,`initialize()`更适合执行业务逻辑和初始化操作。
以下是基于测试结果和个人理解得出的结论:
- `__construct()`主要用于实例化时的基本配置,而`initialize()`则用于加载模型、配置等。- 在实际使用中,`__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()方法是不会再执行了,它关联的是你首次调用的方法,也就是说,方法里面干什么,它管不着了。
推荐教程:thinkphp教程
以上就是thinkphp中__construct()和__initialize()的介绍的详细内容,更多请关注自由互联其它相关文章!

