PHP有一个把戏要领,叫做__call。当你挪用一个不存在的要领时,这个要领会被自动挪用。
这时候,我们就有机会将挪用重定向到一个存在的要领。继续多个父类的子类,寻觅要领的历程平常是如许的:(引荐进修:PHP视频教程)
自身的要领 -> 父类1的要领 -> 父类2的要领...
模仿历程大抵是如许:将各个父类实例化,然后作为子类的属性。这些父类供应一些公有的要领。当子类具有某要领时,__call()函数不会被挪用。这相当于“掩盖”了父类的要领。
当挪用了不存在的要领时,经由过程__call()要领顺次从父类中寻觅能够挪用的要领。虽然这不是完整的多继续,但能够协助我们解决问题。
<?php class Parent1 { function method1() {} function method2() {} } class Parent2 { function method3() {} function method4() {} } class Child { protected $_parents = array(); public function Child(array $parents=array()) { $_parents = $parents; } public function __call($method, $args) { // 从“父类"中查找要领 foreach ($this->_parents as $p) { if (is_callable(array($p, $method))) { return call_user_func_array(array($p, $method), $args); } } // 恢复默许的行动,会激发一个要领不存在的致命毛病 return call_user_func_array(array($this, $method), $args); } } $obj = new Child(array(new Parent1(), new Parent2())); $obj->method1(); $obj->method3();
这里没有触及属性的继续,但完成起来并不难题。能够经由过程__set()和__get()把戏要领来模仿属性的继续。
以上就是php是单继续吗的细致内容,更多请关注ki4网别的相干文章!