Avec l'arrivée d'Angular 18.1, cette version introduit une nouvelle fonctionnalité intéressante dans le compilateur : la possibilité de déclarer une ou plusieurs variables de modèle.
Comment cette fonctionnalité est-elle utilisée et quels sont les différents cas d’utilisation ?
Cet article a pour but de répondre.
Avec les dernières versions d'Angular, l'équipe a introduit de nouvelles fonctionnalités dans le compilateur, et cette fonctionnalité se traduit par la @-syntax.
C'est ainsi qu'est née la nouvelle syntaxe de flux de contrôle
et, plus récemment, @let
En règle générale, le moyen le plus simple de créer une variable de modèle était d'utiliser le
ou en utilisant la nouvelle syntaxe de flux de contrôle
<!-- older control flow syntax --> <div *ngIf="user$ |async as user"> {{ user.name }} </div> <!-- new control flow syntax --> @if(user$ |async; as user){ <div>{{ user.name }}</div> }
Cette fonctionnalité pratique nous a permis de stocker le résultat du canal asynchrone dans une variable pour une utilisation ultérieure dans le modèle.
Cependant, cette syntaxe soulève quelques questions. Ici, la condition vérifie si le retour du canal asynchrone est vrai, et donc si la valeur de retour est différente de toute valeur considérée comme fausse en javascript.
Cette condition fonctionnera très bien si le retour est un objet ou un tableau.
mais si le retour est un chiffre et particulièrement le chiffre 0
@if(((numbers$ |async) !=== undefined || (numbers$ |async) !=== null) ; as myNumber){ <div>{{ myNumber }}</div> }
C'est là qu'intervient @let.
@let ne vérifie pas de condition, il permet juste de déclarer une variable de modèle locale de manière simple
donc l'exemple de code ci-dessus devient beaucoup plus simple et élégant à écrire
@let myNumber = (numbers$ | async) ?? 0; <div>{{ myNumber }}</div>
De cette façon, la variable myNumber sera toujours affichée.
L'un des scénarios les plus classiques avec déclaration de variable consiste à stocker le résultat d'une expression complexe.
Il a toujours été déconseillé d'utiliser une fonction dans une condition. L'utilisation d'une fonction dans une condition avait un impact sur les performances dans le sens où au moindre mouvement de souris, ou changement de template, la fonction était réévaluée.
@let, comme décrit ci-dessus, n'évalue pas, mais déclare simplement une variable locale. Cette variable ne sera réévaluée que si l'une de ses dépendances change. Donc appeler une fonction n'est pas une mauvaise idée pour des expressions telles qu'une expression complexe.
<ul> @for(user of users(); track user.id) { @let isAdmin = checkIfAdmin(user); <li>User is admin: {{ isAdmin }}</li> } </ul>
@let est compatible avec les signaux, et s'utilise comme suit
@let userColor = user().preferences?.colors?.primaryColor || 'white'; <span>user favorite color is {{ userColor }}</span>
Comme vous pouvez le constater, @let peut être utilisé pour évaluer tout type d'expression javascript, hormis par exemple l'instanciation d'une classe
De cette manière, les opérateurs arithmétiques sont interprétés et plusieurs variables peuvent être déclarées sur plusieurs lignes différentes ou sur une seule ligne.
<div> @for (score of scores(); track $index) { @let total = total + score, max = calcMax(score); <h1>final score: {{ total }}</h1> } </div>
Comme décrit ci-dessus, le comportement de @let est très similaire au comportement de let en javascript, ce qui présente les avantages suivants
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!