8 ответов:
есть больше чем один способ сделать это:
$this->{$methodName}($arg1, $arg2, $arg3); $this->$methodName($arg1, $arg2, $arg3); call_user_func_array(array($this, $methodName), array($arg1, $arg2, $arg3));вы даже можете использовать API отражения http://php.net/manual/en/class.reflection.php
вы можете использовать перегрузку в PHP: перегрузка
class Test { private $name; public function __call($name, $arguments) { echo 'Method Name:' . $name . ' Arguments:' . implode(',', $arguments); //do a get if (preg_match('/^get_(.+)/', $name, $matches)) { $var_name = $matches[1]; return $this->$var_name ? $this->$var_name : $arguments[0]; } //do a set if (preg_match('/^set_(.+)/', $name, $matches)) { $var_name = $matches[1]; $this->$var_name = $arguments[0]; } } } $obj = new Test(); $obj->set_name('Any String'); //Echo:Method Name: set_name Arguments:Any String echo $obj->get_name();//Echo:Method Name: get_name Arguments: //return: Any String
Если вы работаете в классе PHP, то я бы рекомендовал использовать перегруженную функцию __call в PHP5. Вы можете найти ссылку здесь.
в основном _ _ call делает для динамических функций то, что __set и __get делают для переменных в OO PHP5.
все еще действует после всех этих лет! Убедитесь, что вы обрезаете $methodName, если это пользовательский контент. Я не мог заставить $this->$methodName работать, пока не заметил, что у него есть ведущее пространство.
в моем случае.
$response = $client->{$this->requestFunc}($this->requestMsg);использование PHP SOAP.
вы можете хранить способ в одной переменной с помощью закрытия:
class test{ function echo_this($text){ echo $text; } function get_method($method){ $object = $this; return function() use($object, $method){ $args = func_get_args(); return call_user_func_array(array($object, $method), $args); }; } } $test = new test(); $echo = $test->get_method('echo_this'); $echo('Hello'); //Output is "Hello"EDIT: я отредактировал код и теперь он совместим с PHP 5.3. Еще один пример здесь
Comments