Maison >interface Web >js tutoriel >Comment éviter les boucles infinies lors de l'ajout dynamique de directives avec AngularJS ?

Comment éviter les boucles infinies lors de l'ajout dynamique de directives avec AngularJS ?

Patricia Arquette
Patricia Arquetteoriginal
2024-11-03 01:39:03810parcourir

How to Avoid Infinite Loops When Adding Directives Dynamically with AngularJS?

Ajout dynamique de directives avec AngularJS

Cet article répond à une préoccupation courante dans le développement d'AngularJS : l'ajout de plusieurs directives à un seul élément DOM. L'objectif est de créer une directive qui ajoute certains attributs, tels que datepicker, datepicker-langage et ng-required, à l'élément cible.

Approche originale : vérification des attributs ajoutés

Au départ, le développeur a tenté de vérifier si les attributs nécessaires avaient déjà été ajoutés avant de les ajouter :

<code class="javascript">if (element.attr('datepicker')) { // check
  return;
}</code>

Cependant, cette approche introduisait une boucle infinie lors de l'utilisation de $compile, puisque $compile tenter de traiter les attributs ajoutés.

Approche mise à jour : utilisation de la priorité et du terminal

Après avoir reçu une contribution externe, le développeur s'est rendu compte que la solution nécessitait de définir à la fois la priorité et le terminal. propriétés de la directive personnalisée. Cette approche implique :

  1. Définir une priorité élevée (par exemple, 1000) pour garantir que la directive personnalisée est compilée en premier.
  2. Définir le terminal sur true pour empêcher la compilation d'autres directives sur le même élément.

Implémentation

Voici un exemple d'implémentation de la directive utilisant la priorité et le terminal :

<code class="javascript">angular.module('app').directive('superDirective', function ($compile) {
  return {
    restrict: 'A',
    replace: false,
    terminal: true,
    priority: 1000,
    link: function (scope, element, attrs) {
      // Remove the "superDirective" attribute to avoid looping.
      element.removeAttr("superDirective");

      // Add the necessary attributes.
      element.attr('datepicker', 'someValue');
      element.attr('datepicker-language', 'en');

      // Compile the element.
      $compile(element)(scope);
    }
  };
});</code>

Cette approche permet la directive personnalisée pour modifier l'élément et ajouter des attributs, puis utilisez $compile pour compiler toutes les directives, y compris celles ignorées en raison du terminal:true.

Explication

Par en définissant le terminal sur true, la directive personnalisée sera la seule directive compilée sur l'élément cible. Cela évite la compilation redondante et les conflits potentiels. La priorité élevée garantit que la directive personnalisée est compilée en premier, ce qui lui permet de modifier l'élément avant que d'autres directives ne tentent d'y accéder.

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!

Déclaration:
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