Maison >développement back-end >tutoriel php >Résumé de quelques nouvelles fonctionnalités utilisées avec php7
Si vous utilisez un framework basé sur Composer et PSR-4, cette méthode d'écriture peut-elle charger avec succès des fichiers de classe ? En fait, c'est possible. La méthode de chargement automatique enregistrée par composer consiste à trouver l'emplacement en fonction de l'espace de noms de la classe lorsque la classe s'appelle , cette façon d'écrire n'a aucun effet sur elle.
1. Opérateur (opérateur de coalescence NULL)
Je mets ceci en premier parce que je pense que c'est très utile. Utilisation :
$a = $_GET['a'] ?? 1;
Il est équivalent à :
<?php $a = isset($_GET['a']) ? $_GET['a'] : 1;
On sait que l'opérateur ternaire peut être utilisé comme ceci :
$a ?: 1
Mais ceci est basé sur le principe que $a a été défini. Le nouvel opérateur ?? peut simplifier le jugement.
2. Déclaration du type de valeur de retour de la fonction
Exemple fourni par le document officiel (remarque... La syntaxe du paramètre de longueur de côté est en PHP 5.6 Uniquement disponible dans les versions ci-dessus) :
<?php function arraysSum(array ...$arrays): array { return array_map(function(array $array): int { return array_sum($array); }, $arrays); } print_r(arraysSum([1,2,3], [4,5,6], [7,8,9]));
À partir de cet exemple, vous pouvez voir que désormais les fonctions (y compris les fonctions anonymes) peuvent spécifier le type de valeur de retour.
L'écriture de cette déclaration est quelque peu similaire à Swift :
func sayHello(personName: String) -> String { let greeting = "Hello, " + personName + "!" return greeting }
Cette fonctionnalité peut nous aider à éviter certains problèmes causés par la conversion de type implicite de PHP. Réfléchir aux résultats attendus avant de définir une fonction peut éviter des erreurs inutiles.
Cependant, il y a aussi une fonctionnalité qui mérite attention ici. PHP 7 ajoute une directive de déclaration : strict_types, qui utilise le mode strict.
Lors de l'utilisation d'une déclaration de type de valeur de retour, si elle n'est pas déclarée en mode strict et si la valeur de retour n'est pas du type attendu, PHP la convertira quand même. Mais s'il s'agit d'un mode strict, une erreur fatale de TypeError sera déclenchée.
Mode Force :
<?php function foo($a) : int { return $a; } foo(1.0);
Le code ci-dessus peut être exécuté normalement et la fonction foo renvoie int 1 sans aucune erreur.
Mode strict :
<?php declare(strict_types=1); function foo($a) : int { return $a; } foo(1.0);
# PHP Erreur fatale : Uncaught TypeError : La valeur de retour de foo() doit être du type entier, float renvoyé dans test.php:6
Après la déclaration, une erreur fatale sera déclenchée.
Est-ce similaire au mode strict de js ?
3. Déclaration de type scalaire
La déclaration formelle de type de paramètre des fonctions en PHP 7 peut être scalaire. En PHP 5, il ne peut s'agir que d'un nom de classe, d'une interface, d'un tableau ou d'un appel (PHP 5.4, il peut s'agir d'une fonction, y compris des fonctions anonymes. Vous pouvez désormais également utiliser string, int, float et bool).
Exemple officiel :
<?php // Coercive mode function sumOfInts(int ...$ints) { return array_sum($ints); } var_dump(sumOfInts(2, '3', 4.1));
Il est à noter que le problème de mode strict mentionné ci-dessus s'applique également ici : en mode forcé (par défaut, qui est une conversion de type forcée), il sera toujours Paramètres qui ne répondent pas aux exigences attendues sont forcés de taper et une erreur fatale TypeError est déclenchée en mode strict.
4. Utiliser la déclaration par lots
En PHP 7, use peut déclarer plusieurs classes ou fonctions ou const en une seule phrase :
<?php use some/namespace/{ClassA, ClassB, ClassC as C}; use function some/namespace/{fn_a, fn_b, fn_c}; use const some/namespace/{ConstA, ConstB, ConstC};
Mais vous devez toujours écrire le nom de chaque classe, fonction ou const (il n'y a pas de méthode d'importation * comme python).
Une question à noter est la suivante : si vous utilisez un framework basé sur Composer et PSR-4, cette méthode d'écriture peut-elle charger avec succès des fichiers de classe ? En fait, c'est possible. La méthode de chargement automatique enregistrée par composer recherche l'emplacement en fonction de l'espace de noms de la classe lorsque la classe est appelée. Cette façon d'écrire n'a aucun effet sur celle-ci.
5. Autres fonctionnalités
Je ne présenterai pas certaines autres fonctionnalités une par une Si vous êtes intéressé, vous pouvez consulter la documentation officielle
Une brève introduction Un : PHP 5.3 a commencé à avoir des fonctions anonymes, et maintenant il y a des classes anonymes La fermeture a été ajoutée ; Une méthode d'appel ;
Un générateur (ou un itérateur, de manière plus appropriée) peut avoir une valeur de retour finale (return), ou il peut entrer un autre générateur (délégué du générateur) via la nouvelle syntaxe de rendement de.
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!