Daten zwischen AngularJS-Controllern teilen
Die Weitergabe von Daten zwischen Controllern ist eine häufige Aufgabe in AngularJS-Anwendungen. Um diesem Bedarf gerecht zu werden, stehen Ihnen mehrere Optionen zur Verfügung, z. B. Dienste, Broadcasts und der $rootScope-Dienst.
Verwendung eines Dienstes
Dienste bieten eine zentralisierte Möglichkeit zur Verwaltung Status und Austausch von Daten zwischen mehreren Komponenten. Um einen Dienst zu erstellen, rufen Sie die Methode „factory()“ des App-Moduls auf und definieren Sie darin Ihre Dienstlogik. Sie könnten beispielsweise einen Produktservice wie folgt erstellen:
app.factory('productService', function() { var productList = []; var addProduct = function(newObj) { productList.push(newObj); }; var getProducts = function(){ return productList; }; return { addProduct: addProduct, getProducts: getProducts }; });
Injecting the Service and Sharing Data
Inject sowohl in Ihrer ProductCtrl als auch in Ihrer CartCtrl den productService als eine Abhängigkeit. Definieren Sie dann in ProductCtrl eine Aktion, die das ausgewählte Produkt zur Produktliste im Service hinzufügt:
app.controller('ProductCtrl', function($scope, productService) { $scope.callToAddToProductList = function(currObj){ productService.addProduct(currObj); }; });
In CartCtrl rufen Sie die Produkte aus dem Service ab:
app.controller('CartCtrl', function($scope, productService) { $scope.products = productService.getProducts(); });
This Der Ansatz ermöglicht es Ihnen, die Datenverarbeitung von den Controllern getrennt zu halten, was die Verwaltung und Wiederverwendung der Daten in verschiedenen Teilen Ihrer Anwendung erleichtert.
Das obige ist der detaillierte Inhalt vonWie kann ich Daten effizient zwischen AngularJS-Controllern teilen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!