Heim >Backend-Entwicklung >PHP-Tutorial >Wie aktualisiert die Fabrik in Angularjs die Daten im Controller nach dem Versprechen?
<code>app.factory('mainClass',function($http,mainFac){ var mainClass=function(){ this.uid; this.sid; this.getUid(); } mainClass.prototype.getUid=function(){ var promise = mainFac.query('OPT','PARM1','PARM2'); promise.then(function(data){ console.info("mainClass is :",data); this.sid=data.sid; console.info("this.sid :",this.sid); }); }; return mainClass; }); app.controller('perCenterCtrl', function($scope, $http, $state, ngDialog, qfact, myfactory,mainFac,mainClass) { var mainObj=new mainClass(); console.info("mainObj is :",mainObj); $scope.sid=mainObj.sid; }); </code>
Codezweck:
Der Controller wird sequentiell ausgeführt, trifft auf die Factory-Initialisierung mit dem Namen mainClass, mainClass wird asynchron initialisiert, ruft die Daten aus dem Hintergrund ab und aktualisiert seine eigene this.sid. Zu diesem Zeitpunkt ist auch $scope.sid vorhanden im Controller aktualisiert. ;
Auf Schwierigkeiten gestoßen:
Mein Verständnis ist: $scope.sid=mainObj.sid; wurde während des mainClass-Ausführungsprozesses asynchron abgerufen und aktualisiert seine eigenen this.sid. , $scope.sid sollte seinen Wert entsprechend aktualisieren, aber er wird nicht aktualisiert;
<code>app.factory('mainClass',function($http,mainFac){ var mainClass=function(){ this.uid; this.sid; this.getUid(); } mainClass.prototype.getUid=function(){ var promise = mainFac.query('OPT','PARM1','PARM2'); promise.then(function(data){ console.info("mainClass is :",data); this.sid=data.sid; console.info("this.sid :",this.sid); }); }; return mainClass; }); app.controller('perCenterCtrl', function($scope, $http, $state, ngDialog, qfact, myfactory,mainFac,mainClass) { var mainObj=new mainClass(); console.info("mainObj is :",mainObj); $scope.sid=mainObj.sid; }); </code>Codezweck:
Der Controller wird sequentiell ausgeführt, trifft auf die Factory-Initialisierung mit dem Namen mainClass, mainClass wird asynchron initialisiert, ruft die Daten aus dem Hintergrund ab und aktualisiert seine eigene this.sid. Zu diesem Zeitpunkt ist auch $scope.sid vorhanden im Controller aktualisiert. ;
Auf Schwierigkeiten gestoßen:
Mein Verständnis ist: $scope.sid=mainObj.sid; wurde während des mainClass-Ausführungsprozesses asynchron abgerufen und aktualisiert seine eigenen this.sid. , $scope.sid sollte seinen Wert entsprechend aktualisieren, aber er wird nicht aktualisiert;
Ich verstehe es nicht ganz, versuchen Sie es so zu schreiben. Ich empfehle Ihnen, einen Blick darauf zu werfen: http://each.sinaapp.com/angular/tutorial/ng-factory.html
<code>app.factory('mainClass',function(mainFac){ function getUid(){ mainFac.query('OPT','PARM1','PARM2').then(function(response){ return response; },function(error){ return error; }); } return {getUid}; }); app.controller('perCenterCtrl', function($scope, $http, $state, ngDialog, qfact, myfactory,mainFac,mainClass) { mainClass.getUid().then(function(data){ console.info("mainObj is :",data); $scope.sid=data.sid; }); }); </code>