Example to understand this function and difference with call_user_func:
<?php
class Beer {
const NAME = 'Beer!';
public static function printed(){
echo 'static Beer:NAME = '. static::NAME . PHP_EOL;
}
}
class Ale extends Beer {
const NAME = 'Ale!';
public static function printed(){
forward_static_call(array('parent','printed'));
call_user_func(array('parent','printed'));
forward_static_call(array('Beer','printed'));
call_user_func(array('Beer','printed'));
}
}
Ale::printed();
echo '</pre>';
?>forward_static_call
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
forward_static_call
Референца за `function.forward-static-call.php` со подобрена типографија и навигација.
forward_static_call
(PHP 5 >= 5.3.0, PHP 7, PHP 8)
forward_static_call — Повикај статичен метод
= NULL
Повикува кориснички дефинирана функција или метод даден од callback
параметарот, со следните аргументи. Оваа функција мора да биде повикана во контекст на метод, не може да се користи надвор од класа. Користи метод на класа или некој од нејзините родители. Покрај тоа, статичките својства или методи може да се пребришат преку.
Параметри
callback-
Функцијата или методот што треба да се повика. Овој параметар може да биде низа, со името на класата и методот, или стринг, со име на функција.
args-
Нула или повеќе параметри што треба да се поминат на функцијата.
Вратени вредности
Враќа резултат од функцијата, или false при грешка.
Примери
Пример #1 forward_static_call() example
<?php
class A
{
const NAME = 'A';
public static function test() {
$args = func_get_args();
echo static::NAME, " ".join(',', $args)." \n";
}
}
class B extends A
{
const NAME = 'B';
public static function test() {
echo self::NAME, "\n";
forward_static_call(array('A', 'test'), 'more', 'args');
forward_static_call( 'test', 'other', 'args');
}
}
B::test('foo');
function test() {
$args = func_get_args();
echo "C ".join(',', $args)." \n";
}
?>Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред
B B more,args C other,args
Види Исто така
- forward_static_call_array() - Повикај статичен метод и поминете ги аргументите како низа
- call_user_func_array() - Повикајте повик со низа од параметри
- call_user_func() - Повикајте ја повратната функција дадена од првиот параметар
- is_callable() - Проверете дали вредноста може да се повика како функција од тековниот опсег
Белешки од корисници 2 забелешки
Example usage via calls outside of the class and within an object:
<?php
/**
* @author Jonathon Hibbard
*/
class foo {
# used to verify we're actually setting something..
private static $value = '';
/**
* Simple setter for the static method setValue...
*/
public static function set($method_identifier, $value_to_pass = '') {
# make sure we have the right method format...
# another semi-useful example is like this (useful for REST-like requests...): str_replace(" ", "", ucwords(str_replace("_", " ", $method_identifier)));
$static_method = 'set' . ucfirst(strtolower(trim($method_identifier)));
if(method_exists(__CLASS__, $static_method)) {
//Note: this will not work and will throw PHP Parse error: syntax error, unexpected '::'
//__CLASS__::$static_method($value_to_pass);
foo::$static_method($value_to_pass);
echo "\tCalling forward_static_call with pure string and value param:\n";
forward_static_call(__CLASS__ . "::" . $static_method, $value_to_pass);
echo "\tCalling forward_static_call with class, method array and value param:\n";
forward_static_call(array(__CLASS__, $static_method), $value_to_pass);
}
}
/**
* Set self::$value to something?
*/
public static function setValue($value_recieved = '') {
echo "\t\tsetValue called with param of " . var_export($value_recieved, true) . "!\n";
echo "\t\tSetting Private 'value'...\n";
self::$value = $value_recieved;
echo "\t\tChecking the Private 'value':\n";
if(!empty(self::$value)) {
echo "\t\t\tPrivate 'value' was set to '" . self::$value . "' as expected!\n";
} else {
echo "\t\t\tPrivate 'value' was not set!\n";
}
# Reset...
self::$value = '';
}
/**
* Create an object and test calling the static method from within this realm...
*/
public function __construct() {
echo "\tCalling from within constructor..\n";
foo::set('value','Something else from within the instance!');
}
}
echo "\n============ Calling by static method first ============\n";
foo::set('value','Something from outside of the foo class!');
echo "\n============ Calling by static method without a value next ============\n";
foo::set('value');
echo "\n============ Calling by createing an instance next ============\n";
new foo();
?>