关于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()方法,然后再执行我们需要的方法,看代码:
<?phpnamespace home\controller;u think\controller;class indexcontroller extends controller { public function __construct() { parent::__construct(); lf::b(); echo '我是构造<br />'; } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ lf::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; }} /*当执行index方法时,打印结果:我先来bbbb我是构造bbbb这是index*/
②:在重写的构造中没有实现父类的构造函数,执行方法时,定义的_initialize()方法则没有作用(不会在执行方法时,先执行_initialize方法),看代码:
<?phpnamespace home\controller;u think\controller;class indexcontroller extends controller { public function __construct() { // parent::__construct(); lf::b(); echo '我是构造<br />'; } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ lf::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; }} /*当执行index方法时,打印结果:bbbb我是构造bbbb这是index*/
注:这里面的所说的先执行_initialize()方法,是在parent::__construct();前没有任何函数调用,如果你非得在p铁锅保养arent::__construct();前来个lf::b(),那没得说,肯定是先执行b(),不过一般不这样写,在实现父类的构造函数前一般没有任何输出和配置 再有,如果是继承,如果父类有构造函数,子类在其构造函数一般先把父类的构造函数先初始化,确保代码的原始性和完整性 2)没有重写构造函数,也就是说在我们定义的控制器中没有声明构造函数 这种情况,如果在控制器中有定义_initialize()方法,则当我们调用其他方法时,会先调用_initialize()方法,看代码:
动画片全集<?phpnamespace home\controller;u think\controller;class indexcontroller extends controller { // public function __construct() { // // parent::__construct(); // lf::b(); // echo '我是构造<br />'; // } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ lf::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; }} /*当执行index方法时,打印结果:我先来bbbb这是index
另外,_initialize()还可以用来继承
<?phpnamespace home\controller;u think\controller;class bacontroller extends controller { public function __construct() { parent::__construct();杜甫诗风 echo '我是父类<br />'; } public function _initialize() { echo '我先来<br />'; } public function a() { echo 'aaaa<br />'; }}
<?phpnamespace home\controller;u think\controller;class indexcontroller extends bacontroller { public function __construct() { parent::__construct(); lf::b(); echo '我是构造<br />'; } public function _initialize() { parent::_initialize(); echo '我是子类先来<br />'; } public function index(){ lf::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; }} /*当执行index方法时,打印结果:我先来我是子类先来我是父类bbbb我是构造bbbb这是index
注意:如果父类的构造函数中没有parent::construct(),定义的_initialize()也不起作用 那么,同时存在__constmy family英语作文ruct()(该构造函数初始化了父类的构造函数)和_initialize() ,到底先执行哪个呢? 答案是——先执行_initialize()方法,也就是说,在满足条件下,_initialize()函数是在任何方法执行之前,都要执行的,包括构造函数, 当然,如果你在要执行的方法中又调用的另一个或者多个方法,在另外调用那些方法时,_initialize()方法是不会再执行了,它关联的是你首次调用的方法,也就是说,方法里面干什么,它管不着了。
更多学习内容请访问:
腾讯t3-t4标准精品php架构师教程目录大全,只要你看完保证薪资上升一个台阶(持续更新)
本文发布于:2023-04-08 13:04:42,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/ff2e10565ca8434ec7a9c3f81d5c9974.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:thinkphp中.doc
本文 PDF 下载地址:thinkphp中.pdf
留言与评论(共有 0 条评论) |