Как вызвать функцию в php
Функции представляют собой блок инструкций, которые многократно можно вызывать в различных частях программы. Функции позволяют разделять программуу на меньшие функциональные части.
Общий синтаксис определения функции выглядит следующим образом:
function имя_функции([параметр [, . ]]) < // Инструкции >
Определение функции начинается с ключевого слова function , за которым следует имя функции. Имя функции должно начинаться с алфавитного символа или подчеркивания, за которыми может следовать любое количество алфавитно-цифровых символов или символов подчеркивания.
После имени функции в скобках идет перечисление параметров. Даже если параметров у функции нет, то просто идут пустые скобки. Затем в фигурных скобках идет тело функции, содержащее набор инструкций.
Определим простейшую функцию:
Данная функция назывется hello . Она не имеет параметров, поэтому после названия функции идут пустые скобки. Блок функции содержит только одну инструкцию, которая выводит сообщение «Hello PHP».
Чтобы функция сработала, ее надо вызвать. Для вызова функции указывается ее имя, после которого в скобках идут значения для ее параметров (если, кончено, она имеет параметры):
название_функции (значения_для_параметров_функции);
Например, вызовем вышеопределенную функцию hello :
hello(); // вызов функции ?>
Поскольку для функции hello мы не определили никаких параметров, то при ее вызове указываем название функции и после нее пустые круглые скобки. Заканчивается вызов функции точкой с запятой.
В итоге браузер выведет сообщение:
Hello PHP
Преимуществом функций является то, что, определив однажды, мы можем многократно их вызывать в различных частях программы:
METANIT.COM Hello PHP"; > hello(); hello(); hello(); ?>

Стоит отметить, что в данном случае сначала определяется функция, а затем она вызывается. Но мы также можно сделать наоборот:
Тем не менее есть исключения. В частности, при определении функции при определенном условии.
// hello(); // здесь будет ошибка if(true) < function hello() < echo "Hello PHP"; >hello(); >
PHP: Определение и вызов функции
Функция — это именованный блок кода, в данном случае на языке PHP, который определяется один раз, а затем может вызываться на исполнение сколько угодно раз.
Определение функции выполняется с помощью ключевого слова function за которым указываются следующие компоненты:
- Идентификатор , определяющий имя функции. Он будет использован для создания новой переменной, которой будет присвоена функция. Имена функций следуют тем же правилам, что и именование переменных. Примечание: имена функций не чувствительны к регистру букв.
- Пара круглых скобок вокруг списка из нуля или более идентификаторов, разделенных запятыми. Эти идентификаторы будут определять имена параметров функции. В теле функции они используются в качестве локальных переменных.
- Пара фигурных скобок с нулем или более инструкций. Эти инструкции составляют тело функции: они выполняются при каждом вызове функции.
Синтаксис определения функции выглядит следующим образом:
function имя_функции([параметры])
Квадратные скобки ( [] ) означают необязательность. Теперь приведем простой пример определения функции:
Для вызова функции используется оператор вызова, представляющий из себя пару круглых скобок. Завершается вызов функции как и все инструкции точкой с запятой ( ; ):
// вызов функции hello(); ?>
При вызове функции исполняются инструкции, расположенные в ее теле.
Функции допускается определять в любом месте программы, это значит, что они не обязательно быть определены до их использования, исключая тот случай, когда функции определяются условно:
> /* Теперь мы можем вызывать функцию foo(), поскольку $makefoo была интерпретирована как true */ foo(); function bar() < echo "Я существую сразу с начала старта программы.\n"; >?>
Все функции в PHP имеют глобальную область видимости — они могут быть вызваны вне функции, даже если были определены внутри и наоборот:
> /* пока нельзя вызвать func2(), поскольку она еще не определена. */ func1(); /* Теперь можно вызвать функцию func2(), вызов func1() сделал ее доступной. */ func2(); ?>
Чаще всего функции работают с каким-либо переданными ей значениями. Для того, чтобы функции можно было передать некоторые значения, в ней должны быть указаны параметры. Эти параметры по сути являются обычными переменными, которые инициализируются переданными значениями при вызове функции.
С этой темой смотрят:
- Параметры и аргументы функции
- Анонимные функции
- Литералы, идентификаторы и инструкции
- Переменные
- Область видимости
Копирование материалов с данного сайта возможно только с разрешения администрации сайта
и при указании прямой активной ссылки на источник.
2011 – 2024 © puzzleweb.ru | razumnikum.ru
Как вызвать функцию в php?
Функцию в PHP можно вызвать, используя следующий синтаксис:
function sayHello($name) return "Привет, $name>!"; > echo sayHello('John'); // => Привет, John!
Как вызвать функцию в php
PHP поддерживает концепцию переменных функций. Это означает, что если к имени переменной присоединены круглые скобки, PHP ищет функцию с тем же именем, что и результат вычисления переменной, и пытается её выполнить. Эту возможность можно использовать для реализации обратных вызовов, таблиц функций и множества других вещей.
Переменные функции не будут работать с такими языковыми конструкциями как echo , print , unset() , isset() , empty() , include , require и т.п. Вам необходимо реализовать свою функцию-обёртку для того, чтобы приведённые выше конструкции могли работать с переменными функциями.
Пример #1 Работа с функциями посредством переменных
function bar ( $arg = » )
echo «В bar(); аргумент был ‘ $arg ‘.
\n» ;
>
// Функция-обёртка для echo
function echoit ( $string )
echo $string ;
>
$func = ‘foo’ ;
$func (); // Вызывает функцию foo()
$func = ‘bar’ ;
$func ( ‘test’ ); // Вызывает функцию bar()
$func = ‘echoit’ ;
$func ( ‘test’ ); // Вызывает функцию echoit()
?>
Вы также можете вызвать методы объекта используя возможности PHP для работы с переменными функциями.
Пример #2 Обращение к методам класса посредством переменных
class Foo
function Variable ()
$name = ‘Bar’ ;
$this -> $name (); // Вызываем метод Bar()
>
?php
$foo = new Foo ();
$funcname = «Variable» ;
$foo -> $funcname (); // Обращаемся к $foo->Variable()
При вызове статических методов вызов функции «сильнее», чем оператор доступа к статическому свойству:
Пример #3 Пример вызова переменного метода со статическим свойством
class Foo
static $variable = ‘статическое свойство’ ;
static function Variable ()
echo ‘Вызов метода Variable’ ;
>
>
?php
echo Foo :: $variable ; // Это выведет ‘статическое свойство’. Переменная $variable будет разрешена в этой области видимости.
$variable = «Variable» ;
Foo :: $variable (); // Это вызовет $foo->Variable(), прочитав $variable из этой области видимости.
Пример #4 Сложные callable-функции
$func = array( «Foo» , «bar» );
$func (); // выведет «bar»
$func = array(new Foo , «baz» );
$func (); // выведет «baz»
$func = «Foo::bar» ;
$func (); // выведет «bar»
?>
Смотрите также
- is_callable()
- call_user_func()
- function_exists()
- переменные переменных
User Contributed Notes 6 notes
4 years ago
While the documentation suggests that the use of a constant is similar to the use of a variable, there is an exception regarding variable functions. You cannot use a constant as the function name to call a variable function.
const DEBUGME =’func’;
function func($s)
DEBUGME(‘abc’); // results in a syntax error
$call = DEBUGME;
$call(‘abc’); // does the job
But you can use a constant as an argument to a function. Here’s a simple workaround when you need to call a variable constant function:
function dynamic($what, $with)
$what($with);
>
dynamic(DEBUGME, ‘abc’);
This makes sense to me to hide API’s and/or long (complicated) static calls.
Enjoy!
12 years ago
List of functions that accept variable arguments.
array_diff_assoc ()
array_diff_key ()
array_diff_uassoc ()
array()
array_intersect_ukey ()
array_map ()
array_merge ()
array_merge_recursive ()
array_multisort ()
array_push ()
array_replace ()
array_replace_recursive ()
array_unshift ()
call_user_func ()
call_user_method ()
compact ()
dba_open ()
dba_popen ()
echo()
forward_static_call ()
fprintf ()
fscanf ()
httprequestpool_construct ()
ibase_execute ()
ibase_set_event_handler ()
ibase_wait_event ()
isset()
list()
maxdb_stmt_bind_param ()
maxdb_stmt_bind_result ()
mb_convert_variables ()
newt_checkbox_tree_add_item ()
newt_grid_h_close_stacked ()
newt_grid_h_stacked ()
newt_grid_v_close_stacked ()
newt_grid_v_stacked ()
newt_win_choice ()
newt_win_entries ()
newt_win_menu ()
newt_win_message ()
newt_win_ternary ()
pack ()
printf ()
register_shutdown_function ()
register_tick_function ()
session_register ()
setlocale ()
sprintf ()
sscanf ()
unset()
var_dump ()
w32api_deftype ()
w32api_init_dtype ()
w32api_invoke_function ()
wddx_add_vars ()
wddx_serialize_vars ()
?>
3 years ago
/*
You might have found yourself at this php variable functions page because, like me, you wanted to pass functions
around like objects to client objects as you can in JavaScript. The issue I ran into was although
I could call a function using a variable like this » $v(); «. I could not do it like this » $obj->p() » where
‘p’ is a property containing the name of the method to call. Did not want to save my property off to a variable prior
to making my call: » $v = $obj->p; $v(); «; even if one finds a way, the below applies.
?php
I credit this expanded work to this person: tatarynowicz at gmail dot com;
without them I would not have gotten here.
*/
interface iface_dynamic_members //Use of this interface enables type-hinting for objects that implement it.
public function __call ( $name , $args );
public function __set ( $name , $value );
public function quietly_fail (): bool ;
>
trait trait_has_dynamic_members //Implementing these magic methods in the form of a trait, frees the client object up
//so it can still inherit from a parent-class.
public function __call ( $name , $args ) if ( is_callable ( $this -> $name )) return call_user_func ( $this -> $name , $args );
>
else //Your dynamic-membered object can declare itself as willing to ignore non-existent method calls or not.
if( $this -> quietly_fail ()=== true ) echo ‘Method does not exist, but I do not mind.’ ;
>else echo ‘Method does not exist, I consider this a bug.’ ;
>
>
>
public function __set ( $name , $value ) $this -> $name = is_callable ( $value ) ? $value -> bindTo ( $this , $this ): $value ; //Assignment using ternary operator.
>
>
abstract class MBR_ATTR //A class full of attributes that objects can take on; abstract since not to be instantiated (If I could make it «final» as well, I would).
public static function is_a_walker ( iface_dynamic_members $obj , ? string $walker_type = ‘normal pace’ ) $obj -> walker_type = $walker_type ;
$obj -> walker_walk = function() return «I am walking < $this ->walker_type > .» ;
>;
>
public static function is_a_runner ( iface_dynamic_members $obj , string $runner_type ) $obj -> runner_type = $runner_type ;
$obj -> runner_run = function() return «I am running < $this ->runner_type > .» ;
>;
self :: is_a_walker ( $obj ); //If can run, also can walk.
>
>
class cls_partly_dynamic implements iface_dynamic_members use trait_has_dynamic_members ;
public function quietly_fail (): bool return true ;
>
>
// Report all errors except E_NOTICE
error_reporting ( E_ALL & ~ E_NOTICE ); //Enable all error-reporting except notices.
//—-
//config runner object.
$obj_runner = new cls_partly_dynamic ();
MBR_ATTR :: is_a_runner ( $obj_runner , ‘fast’ );
$obj_runner -> runner_type = ‘a bit slow’ ;
//—-
//config walker object.
$obj_walker = new cls_partly_dynamic ();
MBR_ATTR :: is_a_walker ( $obj_walker , ‘slow’ );
$obj_walker -> walker_type = ‘super fast’ ;
//—-
//Do stuff.
echo ‘walker in action. ‘ . ‘
‘ ;
echo $obj_walker -> walker_walk () . ‘
‘ ;
echo ‘
‘ ;
echo ‘runner in action. ‘ . ‘
‘ ;
echo $obj_runner -> walker_walk () . ‘
‘ ;
echo $obj_runner -> runner_run () . ‘
‘ ;
echo $obj_runner -> xxx () . ‘
‘ ; //Try calling a non-existent method.
//I would agree that the above approach/technique is not always ideal, particulary due to the loss of code-completion in your
//IDE of choice; I would tend to use this approach for dynamic-programming in response to the user dictating processing steps via a UI.
?>
3 years ago
If you are here looking for a function reference, this is NOT how to do it:
function func1 ()< echo "hell0 1" ;>
$choice = func1 ; // no quotes
?>
It works, but $choice is not what you might think, a reference to a function. It is simply the name of the function as a string, written without (!) quotes.
It’s the same as
$choice = «func1» ; // with quotes
?>
You can do echo gettype($choice) to confirm.
So calling
$choice ()
?>
is a variable-function for both cases, calling it by its name, not by reference.
Go via an assigned anonymous function to get a reference to the function:
$func1 = function()< echo "hell0 1" ;>
$func1 = function()< echo "hell0 2" ;>
?>
Now you can pass around the function like a first class object
$choice = $func1 ;
?>
or
$choice = $func2 ;
?>
and call it
$choice ();
?>
If you want to pass around a class method, use the «Complex callables» from the manual, above. It’s a call by name (not a reference), but since you can include the object you can still get the flexibility you want:
class C <
function k () < echo "inside k" ;>
function j ()< echo "inside j" ; return array( $this , "k" );>>;
?>
You can use $this as the object in the first element of the array.
$c = new C ;
$c -> k ();
inside k
$func = $c -> j ();
inside j
?>
And now, le moment supreme:
$func ();
inside k
?>
1 year ago
static bar method works with statically or non statically wherese non static method could not work statically
?php
//non static method
class myCls public function foo () echo «foo function» ;
>
static public function bar () echo «static bar function» ;
$a = new myCls ;
$myf = «foo» ;
$a -> $myf (); //works
echo «\n» ;
$a = [new myCls , «foo» ]; //works
$a ();
echo «\n» ;
//$a = [«myCls»,»foo»];//fatal error
//$a();
echo «\n» ;
//$a = «myCls::foo»;//fatal error
//$a();
echo «\n» ;
//static method called with statically or nonstatically
$b = new myCls ;
$myf = «bar» ;
$b -> $myf (); //works
echo «\n» ;
$b = [new myCls , «bar» ]; //works
$b ();
echo «\n» ;
$b = «myCls::bar» ; //works
$b ();
echo «\n» ;
$b = [ «myCls» , «bar» ]; //works
$b ();
echo «\n» ;
7 years ago
A small, but helpful note. If you are trying to call a static function from a different namespace, you must use the fully qualified namespace, even if they have the same top level namespace(s). For example if you have the following class to call:
namespace Project\TestClass ;
class Test static function funcToCall () return «test» ;
>
>
?>
You must call it as:
namespace Project\OtherTestClass ;
class OtherTest static function callOtherFunc () $func = ‘\Project\TestClass::funcToCall’ ;
$func ();
>
>
?>
and not:
class OtherTest static function callOtherFunc () $func = ‘TestClass::funcToCall’ ;
$func ();
>
>
?>
- Функции
- Функции, определяемые пользователем
- Аргументы функции
- Возврат значений
- Обращение к функциям через переменные
- Встроенные функции
- Анонимные функции
- Стрелочные функции
- Callback-функции как объекты первого класса
- Copyright © 2001-2024 The PHP Group
- My PHP.net
- Contact
- Other PHP.net sites
- Privacy policy