PHP.mk документација

ReflectionMethod::invokeArgs

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

reflectionmethod.invokeargs.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека reflectionmethod.invokeargs.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
ReflectionMethod::invokeArgs

Референца за `reflectionmethod.invokeargs.php` со подобрена типографија и навигација.

reflectionmethod.invokeargs.php

ReflectionMethod::invokeArgs

(PHP 5 >= 5.1.2, PHP 7, PHP 8)

ReflectionMethod::invokeArgsПовикај аргументи

= NULL

public ReflectionMethod::invokeArgs(?object $object, array $args): mixed

Го повикува рефлектираниот метод и ги поминува неговите аргументи како низа.

Параметри

object

Објектот на кој треба да се повика методот. Во случај на статични методи, можете да поминете null на овој параметар.

args

Параметрите што треба да се поминат на функцијата, како array.

Вратени вредности

Враќа резултат од методот.

Errors/Exceptions

А ReflectionException ако object параметарот не содржи инстанца на класата во која е деклариран овој метод.

А ReflectionException ако повикувањето на методот не успеа.

Дневник на промени

Верзија = NULL
8.0.0 args клучевите сега ќе се толкуваат како имиња на параметри, наместо да се игнорираат тивко.

Примери

Пример #1 ReflectionMethod::invokeArgs() example

<?php
class HelloWorld {

public function
sayHelloTo($name) {
return
'Hello ' . $name;
}

}

$reflectionMethod = new ReflectionMethod('HelloWorld', 'sayHelloTo');
echo
$reflectionMethod->invokeArgs(new HelloWorld(), array('Mike'));
?>

Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред

Hello Mike

Белешки

Забелешка:

Ако функцијата има аргументи што треба да бидат референци, тогаш тие мора да бидат референци во предадената листа на аргументи.

Види Исто така

Белешки од корисници 4 белешки

serg dot smertin at gmail dot com
пред 15 години
We can do black magic, which is useful in templating block calls:

<?php
     $object->__named('methodNameHere', array('arg3' => 'three', 'arg1' => 'one'));

     ...

      /**
       * Pass method arguments by name
       *
       * @param string $method
       * @param array $args
       * @return mixed
       */
      public function __named($method, array $args = array())
      {
        $reflection = new ReflectionMethod($this, $method);

        $pass = array();
        foreach($reflection->getParameters() as $param)
        {
          /* @var $param ReflectionParameter */
          if(isset($args[$param->getName()]))
          {
            $pass[] = $args[$param->getName()];
          }
          else
          {
            $pass[] = $param->getDefaultValue();
          }
        }

        return $reflection->invokeArgs($this, $pass);
      }
?>
agent_harris at secure-mail dot biz
пред 15 години
There is a simple workaround for the reference passing problem:
Since the reflection api has to handle all parameters in a generic way it has no chance to guess if you wish to pass data per value or reference.

But it seems that you can also decide to pass a reference from where you call the function or method (not just only by the ampersand prefix in its declaration).

So just do the following; which worked for me:

<?php
//...
$method->invoke($object, $inputValue, &$outputValue);
?>

Since this will only be necessary with arrays and primitive data types it should be acceptable in most cases to know in advance if you need to pass per reference. But it is probably although necessary to keep the ampersand always in the declaration (because of the at least two layers between the actual function and your invoke call).

If this is the expected behavior it will maybe make sense to mention it in the documentation for invoke and invokeArgs.
CodeCoutureXX at gmail dot com
пред 10 години
If you need to call ReflectionMethod::invokeArgs() on a static function you can pass NULL in for the $object parameter.

Example:

<?php
     class myClass {
          public static myStaticFunc($a, $b) {
               return $a + $b;
          }
     }

     $ref = new ReflectionMethod('myClass', 'myStaticFunc');
     echo $ref->invokeArgs(NULL, [12, 7]);
?>

produces the following output:

19
jonathon точка keogh на gmail точка com
пред 15 години
Passing arguments by reference works:
<?php $rm->invokeArgs($object, array(&$foo, $bar)); ?>
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.