Home > Backend Development > PHP Problem > Focus on the second parameter of the PHP __call() method

Focus on the second parameter of the PHP __call() method

PHPz
Release: 2023-04-12 11:23:13
Original
715 people have browsed it

One of PHP’s magic methods is __call(). The __call() method is used to automatically call a method that does not exist. This method is defined in a class. When an object calls a method that does not exist or has insufficient permissions, the system will automatically call the __call() method. The __call() method accepts two parameters: method name and parameter list. In this article, we will focus on the second parameter of the __call() method, which is the parameter list.

Usage of __call() method

In PHP, the definition format of __call() method is as follows:

public function __call($name, $arguments)
{
    //处理调用$name方法时传递的$arguments参数
}
Copy after login

The $name parameter is the name of the called method, and the $arguments parameter is the parameter array passed to the method.

The following is an example:

class MyClass
{
    public function __call($name, $arguments)
    {
        echo "调用方法 $name() 时,传递了以下参数:";
        print_r ($arguments);
    }
}

$obj = new MyClass();
$obj->hello("World", 123);
Copy after login

In this example, we define a MyClass class, which has a __call() method to handle method calls that do not exist in the class . We create an object of MyClass and call its hello() method. Since the hello() method does not exist in the MyClass class, the system will automatically call the __call() method and pass the method name hello and parameter list ["World", 123] as parameters to the __call() method. The __call() method will output the following results:

调用方法 hello() 时,传递了以下参数:Array ( [0] => World [1] => 123 )
Copy after login

Parameter list of __call() method

In the __call() method, the second parameter $arguments is an array, which contains All parameters passed by the called method. These parameters are stored in $arguments as an array. Inside the __call() method, we can use code similar to the following to get these parameters:

public function __call($name, $arguments)
{
    $arg_count = count($arguments);
    for($i=0; $i<$arg_count; $i++){
        echo $arguments[$i]."<br>";
    }
}
Copy after login

In this example, we use the count() function to count the number of parameters, and then use a for loop to Output parameters one by one.

Application scenarios of magic methods

By using the __call() method, we can make our classes more flexible and easy to extend. When the defined class needs to dynamically call methods, the __call() method can provide us with great help. The following are some application scenarios for the __call() method:

  1. Dynamic methods of calling objects

Web applications usually have many different modules and operations. When the defined class needs to dynamically call methods, it is more appropriate to use __call(). For example:

class Show    
{    
    public function showtext() {    
        return '这是一个文本框';    
    }    
    public function showbutton() {    
        return '这是一个按钮';    
    }    
    public function showselect() {    
        return '这是一个下拉列表';    
    }   
    public function __call($name, $arguments) {    
        return '您调用的方法:'.$name.'(参数:'.implode(',',$arguments).')不存在';    
    }    
}  
$obj = new Show();  
echo $obj->showText().'<br>';    
echo $obj->showButton().'<br>';    
echo $obj->showSelect('',2,3).'<br>';    
echo $obj->test('param1',2).'<br>';
Copy after login

The output result is:

这是一个文本框
这是一个按钮
这是一个下拉列表
您调用的方法:test(参数:param1,2)不存在
Copy after login

By calling the __call() method, we can dynamically implement method calls in the class and uniformly handle non-existent method calls.

  1. Implementing interface class extension

Sometimes, we need to add new methods to the existing code base, but existing classes cannot be modified directly. In this case, you can use the __call() method to implement a delegate method and forward the call to another class. For example:

interface InterfaceA{ 
    public function sayHello($name); 
}

class ClassA implements InterfaceA { 
  public function sayHello($name){                  
      echo 'ClassA: Hello,'.$name.'<br>';                      
  } 
} 

class ClassB { 
  public function __call($name,$arguments){                  
      if($name == 'sayHello'){                     
        $obj = new ClassA(); 
        return $obj->sayHello($arguments[0]); 
      } 
  }   
} 

$obj = new ClassB(); 
$obj->sayHello('World');
Copy after login

In this example, we define an interface InterfaceA and a class ClassA that implements it. Then we defined a ClassB class and implemented the __call() method in it, using delegation to call the ClassA method. Finally, we create an object of ClassB and call its sayHello() method. Since the sayHello() method is not implemented in ClassB, the system will automatically call the __call() method and pass the method name and method parameters as parameters. The __call() method is equivalent to a repeater here.

Summary

In this article, we introduced a very practical magic method __call() in PHP. We learned about the definition of the __call() method, how to call it, and the role of the parameter list. By using the __call() method, we can add the ability to dynamically call methods to a class, which can make our program more flexible and easy to expand. Through this article, you should have a clearer understanding of the __call() method and be able to better apply it in practice.

The above is the detailed content of Focus on the second parameter of the PHP __call() method. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template