这个问题很简单,我敢肯定,我只是不知道答案。
我有一个扩展另一个类的类。当我尝试使用 parent::method 使用父类中的功能时,我得到“调用未定义的方法'parentClass'::getid()”。
它的作用是强制方法名称小写。从上面的示例中, parent::getId() 被强制为 parent::getid();
我不知道这是为什么?有什么想法吗?
代码示例
Class myClass extends OtherClass {
public function getProductList() {
//does other stuff
return parent::getId();
}
}
试图运行 parent::getid() 而不是 parent::getId()。getId() 只是作为数据库模型类的父类的 getter。
也在本地工作,只有在我的测试版推送之后才发生这种情况。
更新
parent::getId()
调用__call
方法
/**
* @method __call
* @public
* @brief Facilitates the magic getters and setters.
* @description
* Allows for the use of getters and setters for accessing data. An exception will be thrown for
* any call that is not either already defined or is not a getter or setter for a member of the
* internal data array.
* @example
* class MyCodeModelUser extends TruDatabaseModel {
* ...
* protected $data = array(
* 'id' => null,
* 'name' => null
* );
* ...
* }
*
* ...
*
* $user->getId(); //gets the id
* $user->setId(2); //sets the id
* $user->setDateOfBirth('1/1/1980'); //throws an undefined method exception
*/
public function __call ($function, $arguments) {
$original = $function;
$function = strtolower(preg_replace('/(?<=[a-z])([A-Z])/', '_$1', $function));
$prefix = substr($function, 0, 4);
if ($prefix == 'get_' || $prefix == 'set_') {
$key = substr($function, 4);
if (array_key_exists($key, $this->data)) {
if ($prefix == 'get_') {
return $this->data[$key];
} else {
$this->data[$key] = $arguments[0];
return;
}
}
}
$this->tru->error->throwException(array(
'type' => 'database.model',
'dependency' => array(
'basic',
'database'
)
), 'Call to undefined method '.get_class($this).'::'.$original.'()');
}
这是一个在 PHP.net 上引发相同错误的示例:http ://www.php.net/manual/en/keyword.parent.php#91315