Ir al contenido principal

AngularJS: Services

Services

TYPE of Services



SetTimeout & setInterval

Using functions










Using services

In the JS file use it as:
   $interval (  functionName, 2000 );



$timeout.cancel(<fuction>)





UI Services

$location -> moves to a specific ID element
$anchorScroll -> moves the web pages to a specific part

Ex. 
      $location.hash( "IDelement" );
      $anchorScroll();
       

Register a Service



Custom services

In another file
  • Create the services using a IIFE function

( function() {

var github = function(){

     var getUser = function(user ){

     };

      var anotherFunction = function(){

     };


     return{
           getUser : getUser ,
           anotherFunction:  anotherFunction ;
     };

}; // End of the service


  • Invoke the module where the service will be used
  • This line should be in the IIFE function
     var module = angular.module( " moduleName " );

  • Register the service

       module.factory( "github", github );


}());


Implementing Service in Controller

var mainController = function($scope, $http, github ) {
$scope.title = mainService.main.title;
}



$resource


  • To request Restful web services
In the Service


(function() {
var app = angular.module('app');
app.factory("performanceLevelService", function($resource, $http) {
var restPerformanceLevel = $resource('/api/v1/performanceLevel/:id', {
id : '@id'
}, {
'update' : {
method : 'PUT'
}
}
);
return {
getEvaluation : function(id) {
return restPerformanceLevel.get({
id : id
});
}
}
});
}());


In the Controller

$scope.performanceLevelService = performanceLevelService .getEvaluation(evaluationService.js);


  • To write in the disk


var resource = $resource('/data/event:id', {id: '@id'} )

  • id is part of the attributes of event
resource.save(event);








$anchorScroll

Go to an specific ID element putting in the URL   ##<Id>

$anchorScroll();



$cacheFactory


app.factory('mycache', function($cacheFactory){
      return $cacheFactory('mycache', {capacity:3});
  • or withour any limit
     return $cacheFactory('mycache');
})


  • In the controller
app.controller('MyCacheController', function CacheSample($scope){
     
       $scope.addToCache = function(key, value){
           mycache.put(key, value);
     };


    $scope.readCache = function(key){
           mycache.get(key);
     };


    $scope.getCacheStatus = function(key, value){
           mycache.info();
     };



});



Exceptions


  • In the service
app.factory('MyException', function(){

    return function (exception){
          console.log('Error in ' + exception.message);
   };

})

  • In the controller

throw {message : 'error message'}


$cookieStore


$cookieStore.put(key, value);

$cookieStore.get(key);

$cookieStore.remove(key);



$rootScope

Can be used to put global variables, it contains all the $scope created by any controller



$window

$document

$rootElement


















Comentarios

Entradas populares de este blog

Android - Basic Steps (Service)

Service Run in the main thread of the hosting application Android can kill the Service if need the resources Purpose Supporting inter-application method execution Performing background processing Start a Service Call Context.startService(Intent intent)\ To call from a Fragment use getActivity().getApplicationContext().startService( intentService); Executing the service After call startService(...)  In the Service is executed the method onStartCommand(...) If the method returns the constant START_NOT_STICKY then Android will not restart the service automatically if the the process is killedp Foreground To execute the service foreground call the method startForeground() Use this if the user is aware of the process Bind to a Service Call the method Context.bindService( Intent service ServiceConnection con int flags ) Send Toast from the Service On the method onStartCommand receive the message   ...

Android - Basic Steps (Location & Maps)

Location Is composed by Latitude Longitude Time-stamp Accuracy Altitude Speed Bearing LocationProvider Types: Network  Wifi access points Cell phone towers GPS Passive Piggyback on the readings requested by other application Permissions Network  android.permission.ACCESS_COARSE_LOCATION android.permission.ACCESS_FINE_LOCATION GPS android.permission.ACCESS_FINE_LOCATION Passive Provider android.permission.ACCESS_FINE_LOCATION LocationManager System service for accessing location data getSystemService( Context.LOCATION_SERVICE ) Functions Determine the last known user location Register for location update Register to receive intents when the device nears or move away from a given geographic area LocationListener Defines callbacks methods that are called when Location or LocationProvider status change. Methods onLocationChanged(...) onProviderDisabled(...) onProviderEnabled(...) onStatusChan...

IIS - Permisions

IIS Permissions To enable the Active Directory connection in the IIS, follow the next steps: Go to IIS Go to Application Pool Select your App Pool Select Advanced Settings in the right side In the section Process Model Select in Identity value the property " NetworkService " You don´t need to restart your application