PHP Magic Methods
Summary: in this tutorial, you will learn about PHP magic methods that override the default actions when the object performs the actions.
Introduction to PHP magic methods
PHP magic methods are special methods in a class. The magic methods override the default actions when the object performs the actions.
By convention, the names of magic methods start with a double underscore ( __ ). And PHP reserves the methods whose names start with a double underscore ( __ ) for magic methods.
So far, you have learned that the constructor and destructor use the __construct() and __destruct() methods. In fact, the constructor and destructor are also magic methods.
The __construct() method is invoked automatically when an object is created and the __destruct() is called when the object is deleted.
Besides the __contruct() and __destruct() methods, PHP also has the following magic methods:
Magic Method | Description |
---|---|
__call() | is triggered when invoking an inaccessible instance method |
__callStatic() | is triggered when invoking an inaccessible static method |
__get() | is invoked when reading the value from a non-existing or inaccessible property |
__set() | is invoked when writing a value to a non-existing or inaccessible property |
__isset() | is triggered by calling isset() or empty() on a non-existing or inaccessible property |
__unset() | is invoked when unset() is used on a non-existing or inaccessible property. |
__sleep() | The __sleep() commits the pending data |
__wakeup() | is invoked when the unserialize() runs to reconstruct any resource that an object may have. |
__serialize() | The serialize() calls __serialize(), if available, and construct and return an associative array of key/value pairs that represent the serialized form of the object. |
__unserialize() | The unserialize() calls __unserialize(), if avaialble, and restore the properties of the object from the array returned by the __unserialize() method. |
__toString() | is invoked when an object of a class is treated as a string. |
__invoke() | is invoked when an object is called as a function |
__set_state() | is called for a class exported by var_export() |
__clone() | is called once the cloning is complete |
__debugInfo() | is called by var_dump() when dumping an object to get the properties that should be shown. |
This tutorial will focus on the __set() and __get() methods.
PHP __set() method
When you attempt to write to a non-existing or inaccessible property, PHP calls the __set() method automatically. The following shows the syntax of the __set() method:
public __set ( string $name , mixed $value ) : void
Code language: PHP (php)
The __set() method accepts the name and value of the property that you write to. The following example illustrates how to use the __set() method:
class HtmlElement < private $attributes = []; private $tag; public function __construct($tag) < $this->tag = $tag; > public function __set($name, $value) < $this->attributes[$name] = $value; > public function html($innerHTML = '') < $html = "tag>"; foreach ($this->attributes as $key => $value) < $html .= ' ' . $key . ' hljs-string">'"'; > $html .= '>'; $html .= $innerHTML; $html .= "$this->tag>"; return $html; > >
Code language: HTML, XML (xml)
- First, define the HTMLElement class that has only one property $attributes . It will hold all the attributes of the HTML element e.g., id and class.
- Second, initialize the constructor with a tag name. The tag name can be any string such as div, article, main, and section.
- Third, implement the __set() method that adds any property to the $attribute array.
- Fourth, define the html() method that returns the HTML representation of the element.
The following uses the HTMLElement class and create a new div element:
require 'HTMLElement.php'; $div = new HtmlElement('div'); $div->id = 'page'; $div->class = 'light'; echo $div->html('Hello');
Code language: HTML, XML (xml)
div id="page" class="light">
Hello div>Code language: HTML, XML (xml)
The following code attempts to write to the non-existing property:
$div->id = 'page'; $div->class = 'light';
Code language: PHP (php)
PHP calls the __set() method implictily and adds these properties to the $attribute property.
PHP __get() method
When you attempt to access a property that doesn’t exist or a property that is in-accessible e.g., private or protected property, PHP automatically calls the __get() method.
The __get() method accepts one argument which is the name of the property that you want to access:
public __get ( string $name ) : mixed
Code language: PHP (php)
The following adds the __get() method to the HTMLElement class:
class HtmlElement < private $attributes = []; private $tag; public function __construct($tag) < $this->tag = $tag; > public function __set($name, $value) < $this->attributes[$name] = $value; > public function __get($name) < if (array_key_exists($name, $this->attributes)) < return $this->attributes[$name]; > > public function html($innerHTML = '') < $html = "tag>"; foreach ($this->attributes as $key => $value) < $html .= ' ' . $key . ' hljs-string">'"'; > $html .= '>'; $html .= $innerHTML; $html .= "$this->tag>"; return $html; > >
Code language: HTML, XML (xml)
The __get() method checks if the requested property exists in the $attributes before returning the result.
The following creates a new article element, sets the id and class attributes, and then shows the value of these attributes:
require 'HTMLElement.php'; $article = new HtmlElement('article'); $article->id = 'main'; $article->class = 'light'; // show the attributes echo $article->class; // light echo $article->id; // main
Code language: HTML, XML (xml)
Summary
- PHP Magic methods start with double underscores (__).
- PHP calls the __get() method automatically when you access a non-existing or inaccessible property.
- PHP calls the __set() method automatically when you assign a value to a non-existing or inaccessible property.