Heim > Web-Frontend > js-Tutorial > Wie können AngularJS-Controller ohne Verschachtelung kommunizieren?

Wie können AngularJS-Controller ohne Verschachtelung kommunizieren?

Linda Hamilton
Freigeben: 2024-12-08 10:13:11
Original
349 Leute haben es durchsucht

How Can AngularJS Controllers Communicate Without Nesting?

Kommunikation zwischen Angular-Controllern

In AngularJS ist es oft notwendig, die Kommunikation zwischen Controllern zu erleichtern. Der Zugriff auf Variablen von einem Controller innerhalb eines anderen stellt jedoch eine Herausforderung dar, wenn die Controller nicht verschachtelt sind.

Variablen ohne Vererbung übergeben

Übergabe des ersten Controllers (Strg1) als Argument an den zweiten Controller (Strg2) mit $scope, Strg1 ist aufgrund undefinierter Fehler nicht möglich. Ähnlich verhält es sich mit der Vererbung von Eigenschaften von Strg1 auf Strg2 mithilfe von Strg2.prototype = new Strg1(); ist ebenfalls erfolglos.

Lösung: Nutzung von Diensten

Um Variablen über Controller hinweg ohne Verschachtelung zu teilen, besteht die effektive Lösung darin, einen Dienst zu erstellen und ihn in alle relevanten Controller einzuschleusen. Ein Dienst ist eine Angular-Komponente, die in mehrere Controller oder Anweisungen eingefügt werden kann, um die Funktionalität zu teilen.

Beispieldienst:

angular.module('myApp').service('sharedProperties', function() {
  var property = 'First';

  return {
    getProperty: function() {
      return property;
    },
    setProperty: function(value) {
      property = value;
    }
  };
});
Nach dem Login kopieren

Verwendung in Controllern:

function Ctrl1($scope, sharedProperties) {
  sharedProperties.setProperty('New First');
}

function Ctrl2($scope, sharedProperties) {
  $scope.prop2 = 'Second';
  $scope.both = sharedProperties.getProperty() + $scope.prop2;
}
Nach dem Login kopieren

Durch die Einbindung des sharedProperties-Dienstes in beide Controller können die gemeinsam genutzten Daten übertragen werden unabhängig voneinander aufgerufen und geändert werden.

Bindung an gemeinsame Werte

Zusätzlich zum Zugriff auf gemeinsame Werte ist es auch möglich, sich im Geltungsbereich des Controllers an sie zu binden. Um die gebundene Referenz beizubehalten, wird empfohlen, eine Bindung an die Eigenschaft eines Objekts statt an einen primitiven Typ vorzunehmen.

var property = { Property1: 'First' };

// Binded to a static copy in Ctrl1
$scope.prop11 = property.Property1;

// Binded to the shared value in Ctrl2
$scope.prop12 = sharedProperties.getProperty().Property1;
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie können AngularJS-Controller ohne Verschachtelung kommunizieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage