Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Menambah Arahan daripada Arahan Induk dalam AngularJS Tanpa Gelung Infinite?

Bagaimana untuk Menambah Arahan daripada Arahan Induk dalam AngularJS Tanpa Gelung Infinite?

Mary-Kate Olsen
Lepaskan: 2024-11-02 18:49:31
asal
818 orang telah melayarinya

How to Add Directives from a Parent Directive in AngularJS Without Infinite Loops?

Menambah Arahan daripada Arahan Induk dalam AngularJS

Dalam AngularJS, seseorang mungkin menghadapi keperluan untuk menambah arahan tambahan pada elemen yang sudah dilengkapi dengan arahan ibu bapa. Walaupun perkhidmatan $compile menawarkan cara untuk mencapai ini, adalah penting untuk mengelakkan gelung tak terhingga.

Untuk mengelakkan isu ini, adalah dinasihatkan untuk memeriksa sama ada atribut yang diperlukan telah dilampirkan pada elemen. Walau bagaimanapun, apabila menggunakan $compile untuk mengemas kini elemen, arahan tidak akan dimulakan.

Adakah Pendekatan ini Sesuai?

Pendekatan yang disebutkan di atas secara amnya sah; walau bagaimanapun, pelarasan mungkin diperlukan untuk memastikan kefungsian yang betul.

Kaedah Alternatif

Penyelesaian alternatif melibatkan memanfaatkan sifat keutamaan untuk menyusun urutan penggunaan arahan pada satu elemen. Arahan dengan nilai keutamaan yang lebih tinggi dilaksanakan terlebih dahulu. Dengan memberikan keutamaan yang tinggi kepada arahan induk, ia boleh memastikan bahawa permulaan arahan itu mendahului arahan anak.

Mengubah Arahan

Berdasarkan perbincangan, perkara berikut versi arahan yang disemak menyediakan penyelesaian yang boleh dilaksanakan.

<code class="javascript">angular.module('app')
  .directive('commonThings', function ($compile) {
    return {
      restrict: 'A',
      replace: false,
      terminal: true, // Prevent subsequent directives from executing
      priority: 1000, // Assign a high priority for early execution
      compile: function compile(element, attrs) {
        // Add additional attributes
        element.attr('tooltip', '{{dt()}}');
        element.attr('tooltip-placement', 'bottom');

        // Remove the parent directive attribute to avoid looping
        element.removeAttr('common-things');
        element.removeAttr('data-common-things');

        return {
          pre: function preLink(scope, iElement, iAttrs, controller) { },
          post: function postLink(scope, iElement, iAttrs, controller) {
            $compile(iElement)(scope);
          },
        };
      },
    };
  });</code>
Salin selepas log masuk

Arahan yang dikemas kini ini menambah dengan berkesan atribut yang diingini sambil menghalang gelung tak terhingga. Ia menggunakan sifat terminal untuk menghentikan pelaksanaan arahan seterusnya, memastikan arahan itu digunakan selepas arahan kanak-kanak telah dimulakan.

Atas ialah kandungan terperinci Bagaimana untuk Menambah Arahan daripada Arahan Induk dalam AngularJS Tanpa Gelung Infinite?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan