Maison > Article > développement back-end > Explication détaillée des méthodes magiques PHP __iset, __unset (exemple de code)
1. Comprendre la définition de la méthode magique en PHP
2 Comprendre les scénarios d'utilisation de la méthode magique __isset()
3. Maîtriser l'utilisation de la méthode magique __isset() 4. Comprendre les scénarios d'utilisation de la méthode magique __unset() 5. Maîtriser l'utilisation de la méthode magique __unset()
PHP réserve toutes les méthodes de classe commençant par __ (deux traits de soulignement) comme méthodes magiques. Par conséquent, lors de la définition des méthodes de classe, à l'exception des méthodes magiques ci-dessus, il est recommandé de ne pas les préfixer par __.
Il existe un autre nom pour ces deux méthodes magiques. Elles peuvent également être appelées méthodes magiques de surcharge d'attributs
Jusqu'à présent, nous avons appris 4 méthodes magiques de surcharge d'attributs, ainsi que les deux autres __get,__set de l'article précédent
Lorsque nous voulons éviter de signaler une erreur lorsque isset (attribut inexistant) ou vide (attribut inexistant), nous pouvons définir la méthode magique __isset dans la classe, et elle sera automatiquement exécutée à ce moment-là. temps
Résumé :
1. En PHP, __isset est défini dans la classe au format suivant : fonction publique __isset (paramètre 1). ce doit être __isset, et ce doit être Avec 1 paramètre, ni plus ni moins ne fonctionnera
2 Lorsque isset n'existe pas pour un attribut, le système déclenchera automatiquement la méthode __isset définie de la classe où l'attribut. l'objet est localisé
3. Lorsque empty() n'existe pas, le système déclenchera automatiquement la méthode __isset définie de la classe où se trouve l'objet
Chaque résumé est obtenu via pratique, et maintenant nous utilisons la pratique pour démontrer le résumé, cela peut favoriser la compréhension et rendre chaque résumé plus clair et intuitif
Cas 1 ,
Objectifs pratiques :
1. En PHP, __isset est défini dans la classe sous le format suivant : fonction publique __isset (paramètre 1). __, qui doit être __isset, et il doit s'agir de 1 paramètre, ni plus ni moins
Le code spécifique est le suivant :
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __isset($name){ echo "自动执行了Animal类中的__isset方法<br/>"; } } $ani = new Animal(); ?>
Le résultat d'exécution est le suivant :
Vide, indiquant qu'aucune erreur n'a été signalée
Maintenant, passons essayez-le sans ajouter de paramètres
Le code spécifique est le suivant :
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __isset(){ echo "自动执行了Animal类中的__isset方法<br/>"; } } $ani = new Animal(); ?>
Le résultat en cours d'exécution est le suivant :
Erreur fatale : la méthode Animal::__isset() doit prendre exactement 1 argument dans D:E-classclass-codeclassingindex .php en ligne 11
par On voit que la méthode __isset a et ne peut avoir qu'un seul paramètre
Cas 2,
Objectifs pratiques :
1. Lorsqu'isset n'existe pas d'attribut, le système déclenchera automatiquement la méthode définie_ _isset
Le code spécifique est le suivant :
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __isset($name){ echo "自动执行了Animal类中的__isset方法<br/>"; } } $ani = new Animal(); isset($ani->name); ?>
Le résultat d'exécution est le suivant :
Exécution automatique de la méthode __isset dans la classe Animal
我们发现其实我们没有手动的去调用__isset方法,也就是说没有写成$ani->__isset(),但是这个方法依然执行了,因为什么呢?因为我们写了isset($ani->name);而这个name属性没有在类中定义,然后这个类中又定义了这个魔术方法,所以它就像魔术一样,突然就被自动执行了
这里一定要注意,是2个下划线,不是一个,否则就不是魔术方法了,下面还是再来做下测试
具体代码如下:
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 试着少写一个_ public function _isset($name){ echo "自动执行了Animal类中的__isset方法<br/>"; } } $ani = new Animal(); isset($ani->name); ?>
运行结果如下:
空白
说明刚刚那个__isset方法没有被自动执行了,所以一定要注意是2个下划线,就好像构造函数和析构函数一样,都是两个下划线
案例三、
实践目标:
1、当empty()不存在的属性时,系统会自动触发对象所在类的定义好的__isset方法
具体代码如下:
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __isset($name){ echo "自动执行了Animal类中的__isset方法<br/>"; } } $ani = new Animal(); empty($ani->name); ?>
运行结果如下:
自动执行了Animal类中的__isset方法
由此可见,会自动触发类中定义好的__iset魔术方法的场景,除了在isset不存在的属性时,还在empty不存在的属性时
当希望在unset()不存在的属性时可以自定义自己的逻辑,我们可以在类中定义__unset方法,此刻它会被自动执行,我们可以在里面写自定义逻辑
总结:
1、PHP中__unset在类中定义格式如下 public function __unset(参数1),这里注意必须是2个__,必须是__unset,而且必须是要带1个参数,多一个少一个都不行
2、当unset不存在的属性时,系统会自动触发对象所在类的定义好的__unset方法
每个总结都是通过实践得出来的,现在我们用实践来演示总结,这样可以促进理解,让每个总结理解起来更加清晰,直观
案例一、
实践目标:
1、PHP中__unset在类中定义格式如下 public function __unset(参数1),这里注意必须是2个__,必须是__unset,而且必须是要带1个参数,多一个少一个都不行
具体代码如下:
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __unset($name){ echo "自动执行了Animal类中的__unset方法<br/>"; } } $ani = new Animal(); ?>
运行结果如下:
空白
说明没有报错,现在我们来试着不写参数看下
具体代码如下:
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __unset(){ echo "自动执行了Animal类中的__unset方法<br/>"; } } $ani = new Animal(); ?>
运行结果为:
Fatal error: Method Animal::__unset() must take exactly 1 argument in D:\E-class\class-code\classing\index.php on line 11
由此可见,__unset魔术方法,参数有且只能有一个
案例二、
实践目标:
1、当unset不存在的属性时,系统会自动触发对象所在类的定义好的__unset方法
具体代码如下:
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 public function __unset($name){ echo "自动执行了Animal类中的__unset方法<br/>"; } } $ani = new Animal(); unset($ani->name); ?>
运行结果如下:
自动执行了Animal类中的__unset方法
我们发现其实我们没有手动的去调用__unset方法,也就是说没有写成$ani->__unset(),但是这个方法依然执行了,因为什么呢?因为我们写了unset($ani->name);而这个name属性没有在类中定义,然后这个类中又定义了这个魔术方法,所以它就像魔术一样,突然就被自动执行了
这里一定要注意,是2个下划线,不是一个,否则就不是魔术方法了,下面还是再来做下测试
具体代码如下:
<?php class Animal{ public function eat(){ } public function sleep(){ } //魔术方法 试着少写一个_ public function _unset($name){ echo "自动执行了Animal类中的__unset方法<br/>"; } } $ani = new Animal(); unset($ani->name); ?>
运行结果如下:
空白
由此可见,__unset魔术方法没有被自动执行了,所以一定要记得__unset魔术方法也是2个下划线
1、本文主要讲了__isset,__unset的使用场景,定义以及具体的实现方法
希望本文能给大家带来一定的帮助,谢谢!!!
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!