In
this article I would like to know you about Passing data between angularjs
controllers using ‘service’, actually we can maintain data  using $sessionStorage throughout the
application. But If we want to pass data from one angularjs controller to other
angularjs controller within the application, then we can use custom service.
For that First declare a service :
app.service('GoodsDetailsService', function () {
    this.Items = function () {
        // if we want
can get data from database 
        goods = { goodsid: '', goodsname:'', quantity:'', price: '' }
    };
    return this;
});
Now
call this service in controller where you want to assign some values and use
them in another controller.
$scope.NavigateToOtherController
= function () {
                    GoodsDetailsService.goodsid
= "1001";
                    GoodsDetailsService.goodsname
= "Mouse";
                    GoodsDetailsService.quantity = "50";
                    GoodsDetailsService.price =
"300";
                    $state.go('stock');                
            }
}]);
Now write another controller, where we want to
receive the previous controllers data as below :
app.controller('StockController', ['$scope', '$http', '$state', 'GoodsDetailsService',
        function ($scope, $http, $state, GoodsDetailsService) {
    $scope.StockReceived.Id
= GoodsDetailsService.goodsid;
    $scope.StockReceived.Name
= GoodsDetailsService.goodsname;
    $scope.StockReceived.Quantity
= GoodsDetailsService.quantity;
    $scope.StockReceived.Price
= GoodsDetailsService.price;
}]);
This is one of the way to pass data from one
controller to other controller using custom service.
 
No comments:
Post a Comment
Note: only a member of this blog may post a comment.