


How does the factory in Angularjs update the data in the controller after the promise?
<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>
Purpose of the code:
The controller is executed sequentially, and when it encounters the factory initialization named mainClass, mainClass is initialized asynchronously, gets the data from the background and updates its own this.sid. At this time, $scope.sid is also updated in the controller;
When it encounters Difficulty:
My understanding is: $scope.sid=mainObj.sid; has been bound. During the mainClass execution process, after asynchronously getting data from the background and updating its own this.sid, $scope.sid should be updated accordingly. My own value, but it is not updated;
Reply content:
<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>
Purpose of the code:
The controller is executed sequentially, and when it encounters the factory initialization named mainClass, mainClass is initialized asynchronously, gets the data from the background and updates its own this.sid. At this time, $scope.sid is also updated in the controller;
When it encounters Difficulty:
My understanding is: $scope.sid=mainObj.sid; has been bound. During the mainClass execution process, after asynchronously getting data from the background and updating its own this.sid, $scope.sid should be updated accordingly. My own value, but it is not updated;
<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>
I don’t quite understand it, try writing it like this. I suggest you take a look at this: http://each.sinaapp.com/angular/tutorial/ng-factory.html

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

The reason for using Dependency Injection (DI) is that it promotes loose coupling, testability, and maintainability of the code. 1) Use constructor to inject dependencies, 2) Avoid using service locators, 3) Use dependency injection containers to manage dependencies, 4) Improve testability through injecting dependencies, 5) Avoid over-injection dependencies, 6) Consider the impact of DI on performance.

PHPperformancetuningiscrucialbecauseitenhancesspeedandefficiency,whicharevitalforwebapplications.1)CachingwithAPCureducesdatabaseloadandimprovesresponsetimes.2)Optimizingdatabasequeriesbyselectingnecessarycolumnsandusingindexingspeedsupdataretrieval.

ThebestpracticesforsendingemailssecurelyinPHPinclude:1)UsingsecureconfigurationswithSMTPandSTARTTLSencryption,2)Validatingandsanitizinginputstopreventinjectionattacks,3)EncryptingsensitivedatawithinemailsusingOpenSSL,4)Properlyhandlingemailheaderstoa

TooptimizePHPapplicationsforperformance,usecaching,databaseoptimization,opcodecaching,andserverconfiguration.1)ImplementcachingwithAPCutoreducedatafetchtimes.2)Optimizedatabasesbyindexing,balancingreadandwriteoperations.3)EnableOPcachetoavoidrecompil

DependencyinjectioninPHPisadesignpatternthatenhancesflexibility,testability,andmaintainabilitybyprovidingexternaldependenciestoclasses.Itallowsforloosecoupling,easiertestingthroughmocking,andmodulardesign,butrequirescarefulstructuringtoavoidover-inje

PHP performance optimization can be achieved through the following steps: 1) use require_once or include_once on the top of the script to reduce the number of file loads; 2) use preprocessing statements and batch processing to reduce the number of database queries; 3) configure OPcache for opcode cache; 4) enable and configure PHP-FPM optimization process management; 5) use CDN to distribute static resources; 6) use Xdebug or Blackfire for code performance analysis; 7) select efficient data structures such as arrays; 8) write modular code for optimization execution.

OpcodecachingsignificantlyimprovesPHPperformancebycachingcompiledcode,reducingserverloadandresponsetimes.1)ItstorescompiledPHPcodeinmemory,bypassingparsingandcompiling.2)UseOPcachebysettingparametersinphp.ini,likememoryconsumptionandscriptlimits.3)Ad


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Dreamweaver Mac version
Visual web development tools

Dreamweaver CS6
Visual web development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
