Maison >développement back-end >tutoriel php >Traits en PHP
Avant-propos
Un ancien collègue a changé de travail et a été interrogé sur les caractéristiques PHP lors de l'entretien. Je ne l'ai jamais utilisé auparavant, donc je n'y ai pas bien répondu. Je l'ai probablement utilisé plusieurs fois, alors j'y ai réfléchi et j'ai compilé le résumé suivant.
trait
le trait est un attribut ou une méthode spécifique que certaines classes (Classe) devraient avoir, et d'autres classes du même parent devraient éviter d'inclure ces attributs lorsqu'ils sont utilisés. en utilisant des méthodes.
Bien sûr, cela est également lié à la capacité du développeur à abstraire les classes. Certaines personnes ayant de bonnes capacités d'abstraction peuvent réduire l'utilisation des traits, mais cette situation devrait être inévitable, sinon les traits n'ont aucun sens si cela n'a aucun sens. apparaît.
Il existe une autre situation, c'est-à-dire que lors de l'utilisation de traits, cela peut jouer un rôle en contraignant les développeurs et en rappelant aux développeurs de prêter attention à certains attributs des traits qui doivent être appelés pendant le processus de développement et. méthodes.
Les collègues ont soulevé une bonne question, l'interface n'a-t-elle pas aussi ce rôle ?
Pas de précipitation, regardons d'abord un exemple :
Par exemple, si vous souhaitez collecter diverses données sur le site Web, vous avez développé la classe Spider . Spider
. Il existe une méthode appelée request()
qui est responsable des requêtes
<?php namespace XWSoul\Network; class Spider { public function request($url) { //do sth. } }
Cependant, lors du processus de collecte de données, certains sites Web sont sensibles aux araignées et d'autres ne le sont pas. Pour les sites Web sensibles, nous avons proposé une solution utilisant un proxy. Cependant, l'utilisation d'un proxy affectera. la vitesse d'exploration. Cela se traduit par Certaines sous-classes de Spider doivent utiliser un proxy, et si possible, essayez de ne pas utiliser de proxy.Nous avons donc ajouté un nouveau trait Proxy :
<?php namespace XWSoul\Network; trait Proxy { protected $isProxy = false; public function useProxy($proxy) { //do sth proxy setups. $this->isProxy = true; return $this; } public function request($url) { if (!$this->isProxy) { throw new Exception("Please using proxy."); } //do sth. return parent::request($url); } }le trait remplace la méthode
de Spider, limitant la levée d'une exception lorsqu'elle est appelée sans appeler de proxy request()
Retour au précédent. question, le trait est comme ça Quelle est la différence entre l'utilisation et l'interface ?
Les contraintes de l'interface sont prédéfinies et doivent être implémentées au début de la définition, mais cela peut contraindre l'implémentation des méthodes. ne peut pas contraindre l'invocation des méthodes.Trait est une sorte de post-appel, il a implémenté la méthode, la clé est qu'elle n'impose des contraintes qu'à la classe qui s'appelle (une phrase absurde), et n'a aucun effet sur la classe qui s'appelle. ne s'appelle pas (encore une phrase absurde). En même temps, il est réutilisable et ne détruit pas l'implémentation de la classe Spider elle-même. Spider est toujours le même Spider.Je pense que l'utilisation. de traits est déjà très efficace ici.Après Ensuite
Quelqu'un peut décider de mettre en œuvre une autre requête, par exemple, proxyRequst. Ne serait-ce pas fini ? Cela a du sens... Cependant, si j'utilise un proxy différent, les détails spécifiques de la demande seront différents. Que dois-je faire si si si dans le code ? Pourquoi devrions-nous abandonner une solution aussi rafraîchissante ? comme un trait ? Pour plus d'articles sur les traits en PHP, veuillez faire attention au site Web chinois de PHP !