Maison > développement back-end > PHP7 > le corps du texte

Nouvelles fonctionnalités PHP8 : Attributs

Guanhui
Libérer: 2023-02-17 15:48:02
avant
3610 Les gens l'ont consulté

Nouvelles fonctionnalités PHP8 : Attributs

La version Alpha de PHP8 sortira dans quelques jours. Elle contient de nombreuses nouvelles fonctionnalités. Bien sûr, je pense que la plus importante est JIT, que j'ai démarré en 2013. Après. En participant, il y a eu de nombreux revers et échecs, et finalement quelque chose a été publié.

Cependant, aujourd'hui, je ne vais pas parler de JIT après la sortie de PHP8, j'écrirai une série distincte similaire à "Compréhension approfondie de JIT en PHP8".

Hé, aujourd'hui, je veux parler des attributs. Pourquoi ? Hier, j'ai vu de nombreux groupes transmettre un article intitulé "Comprendre les attributs en PHP8". l'écriture était difficile à comprendre. Après l'avoir lu, de nombreux étudiants ont déclaré qu'ils étaient confus et n'avaient aucune idée de ce dont ils parlaient.

Alors j'ai pensé que j'utiliserais un article pour expliquer brièvement ce que c'est.

Avant de parler des annotations, parlons des annotations précédentes. On voit souvent quelque chose comme les @param et @see suivants dans les projets PHP :

/**
 * @param Foo $argument
 * @see https:/xxxxxxxx/xxxx/xxx.html
 */    
 function dummy($Foo) {}
Copier après la connexion

Cela s'appelle Commentaires, pour les PHP précédents, le @param et @see dans les commentaires n'avaient aucun sens et le paragraphe entier serait enregistré sous la forme d'une chaîne appelée doc_comment d'une fonction/méthode.

Si nous voulons analyser la signification de ce commentaire, nous devons concevoir une syntaxe spécifique, telle que @+name dans Lili, similaire à @param, puis analyser nous-mêmes cette chaîne pour extraire les informations correspondantes.

Par exemple, si nous voulons obtenir les informations du commentaire See, nous devons effectuer un traitement de chaîne comme :

$ref = new ReflectionFunction("dummy");
$doc = $ref->getDocComment();
$see = substr($doc, strpos($doc, "@see") + strlen("@see "));
Copier après la connexion

, ce qui est relativement gênant et sujet aux erreurs.

En ce qui concerne les attributs, il met en fait à niveau les "annotations" en "annotations" qui prennent en charge le contenu formaté

Par exemple, dans l'exemple ci-dessus :

<?php
<<Params("Foo", "argument")>>
<<See("https://xxxxxxxx/xxxx/xxx.html")>>
function dummy($argument) {}
Copier après la connexion

Ne vous souciez pas du sens d'écrire de cette façon. D'un point de vue fonctionnel, vous pouvez désormais obtenir cette annotation formatée via Reflection. Par exemple, nous souhaitons maintenant obtenir l'annotation See :

$ref = new ReflectionFunction("dummy");

var_dump($ref->getAttributes("See")[0]->getName());
var_dump($ref->getAttributes("See")[0]->getArguments());
Copier après la connexion

will. be output :

string(3) "See"
array(1) {
  [0]=>
  string(30) "https://xxxxxxxx/xxxx/xxx.html"
}
Copier après la connexion

Bien sûr, il existe une utilisation légèrement plus avancée, c'est-à-dire que vous pouvez définir ce qu'on appelle une "classe d'annotation":

<?php
<<phpAttribute>>
class MyAttribute {
	public function __construct($name, $value) {
		var_dump($name);
		var_dumP($value);
	}
}
Copier après la connexion

Ensuite, vous pouvez écrire quelque chose comme , faites attention à l'appel newInstance qu'il contient :

<<MyAttribute("See", "https://xxxxxxxx/xxxx/xxx.html")>>
function dummy($argument) {
}
$ref = new ReflectionFunction("dummy");

$ref->getAttributes("MyAttribute")[0]->newInstance();
Copier après la connexion

Si vous exécutez ce code, vous verrez que la méthode __construct de MyAttribute est appelée et que les paramètres passés dans l'appel sont "See" et "https : //xxx"

Comprenez-vous ? Vous pouvez "instancier" une annotation, puis créer votre propre conception "d'annotation en tant que configuration" basée sur cette fonctionnalité.

Pour résumer, la façon d'écrire les attributs se présente sous la forme suivante :

<<Name>>
<<Name(Arguments)>>
<<Name(Argunment1, Arguments2, ArgumentN)>>
Copier après la connexion

Ensuite, vous pouvez utiliser la série Reflection de méthodes PHP pour obtenir les annotations correspondantes basées sur getAttributes("Name") . De plus, vous pouvez obtenir le nom en appelant la méthode getName de l'annotation renvoyée et obtenir les arguments entre parenthèses avec la méthode getArguments.

De plus, si Name est une classe que vous définissez vous-même avec l'annotation phpAttriubtes, vous pouvez également appeler la méthode newInstance pour implémenter un appel similaire à "new Name(Arguments)".

Beaucoup de gens peuvent se demander, à quoi ça sert ?

Pour être honnête, j'ai toujours été indifférent aux nouvelles fonctionnalités, mais ces attributs devraient quand même avoir un peu

Tutoriel recommandé : "PHP

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!

Étiquettes associées:
php
source:laruence.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal