标签:
林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka
本教程使用AngularJs版本:1.5.3
AngularJs GitHub: https://github.com/angular/angular.js/
AngularJs下载地址:https://angularjs.org/
用有过Spring的人都知道,Spring的核心思想就是DI(依赖注入,Dependency Injection)和IOC(控制反转 Invension of Controller),AngularJS的service其实就是用到了这里的DI思想,那么什么叫做DI?所谓DI,就是指对象是被动接受依赖类而不是自己主动去找,换句话说就是指对象不是从容器中查找它依赖的类,而是在容器实例化对象的时候主动将它依赖的类注入给它。我个人的理解就是,你在实例化一个类时,它会自动去实例化它里面所用到的其它实例。所以这就叫依赖注入。在Angular里面,services作为单例对象在需要到的时候被创建,只有在应用生命周期结束的时候(关闭浏览器)才会被清除。而controllers在不需要的时候就会被销毁了。
AngualrJs中可用来注入的有三种类型,service、factory、provider,这三种写法不样,用法也都不一样。其中,service只实例化一次,其实就是单例模式的思想。无论我们在什么地方注入我们的service,将永远使用同一个实例。所以对很多在controller层中的操作就可以放到serivce层中去。AngularJS提供例如许多内在的服务,如:$http, $route, $window, $location等。每个服务负责例如一个特定的任务,$http是用来创建AJAX调用,以获得服务器的数据。 $route用来定义路由信息等。内置的服务总是前缀$符号。
其中,三者的关系可以看成是下图:
(1)定义
一个学用的service用法如下:
一般直接用this来操作数据、定义函数。
app.service(‘myService‘, function() { var privateValue = "I am Private"; this.variable = "This is public"; this.getPrivate = function() { return privateValue; }; });
(2)AngularJS中使用DI添加Service的三种方法
方式1(内联注解,推荐使用):
app.controller(‘myController‘, [‘$scope‘, ‘dateFilter‘, function ($scope, dateFilter) { }]);方式2($inject注解):
var MyController = function($scope, dateFilter) {} MyController.$inject = [‘$scope‘, ‘dateFilter‘]; someModule.controller(‘MyController‘, MyController);方式3(隐式注解,不推荐使用):
app.controller(‘myController‘, function ($scope, dateFilter) { });推荐使用方式1的理由是:
(3)什么时候适合使用service()方法
service()方法很适合使用在功能控制比较多的service里面
注意:需要使用.config()来配置service的时候不能使用service()方法
(4)service使用实例
一个完整实例:
<!DOCTYPE html> <html lang="zh" ng-app="myApp"> <head> <meta charset="UTF-8"> <title>AngularJS学习</title> <script type="text/javascript" src="./1.5.3/angular.min.js"></script> </head> <body> <div ng-controller="myCtrl"> <button ng-click="getPrivate()">按钮一</button> <button ng-click="getPUbluc()">按钮二</button> </div> <div ng-controller = "myCtrl2"> </div> </body> <script type="text/javascript"> var app = angular.module(‘myApp‘, []); app.controller(‘myCtrl‘, function($scope, myService) { $scope.getPrivate = function() { alert(myService.getPrivate()); }; $scope.getPUbluc = function() { alert(myService.variable); }; }); app.controller(‘myCtrl2‘, function($scope, myService) { }); app.service(‘myService‘, function() { console.log(‘instance myService‘); var privateValue = "I am Private"; this.variable = "This is public"; this.getPrivate = function() { return privateValue; }; }); </script> </html>效果如下:
<!DOCTYPE html> <html lang="zh" ng-app="myApp"> <head> <meta charset="UTF-8"> <title>AngularJS学习</title> <script type="text/javascript" src="./1.5.3/angular.min.js"></script> </head> <body> <div ng-controller="myCtrl"> <button ng-click="getPrivate()">按钮一</button> <button ng-click="getPUbluc()">按钮二</button> </div> <div ng-controller = "myCtrl2"> </div> </body> <script type="text/javascript"> var app = angular.module(‘myApp‘, []); app.controller(‘myCtrl‘, function($scope, myFactory) { $scope.getPrivate = function() { alert(myFactory.getPrivate()); }; $scope.getPUbluc = function() { alert(myFactory.variable); }; }); app.controller(‘myCtrl2‘, function($scope, myFactory) { }); app.factory(‘myFactory‘, function() { console.log(‘instance myFactory‘); var factory = {}; var privateValue = "I am Private"; factory.variable = "This is public"; factory.getPrivate = function() { return privateValue; }; return factory; }); </script> </html>效果:
<!DOCTYPE html> <html lang="zh" ng-app="myApp"> <head> <meta charset="UTF-8"> <title>AngularJS学习</title> <script type="text/javascript" src="./1.5.3/angular.min.js"></script> </head> <body> <div ng-controller="myCtrl1"> <button ng-click = "onclick1()">请点击我1</button> </div> <div ng-controller="myCtrl2"> <button ng-click = "onclick2()">请点击我2</button> </div> </body> <script type="text/javascript"> var app = angular.module(‘myApp‘, []); app.controller(‘myCtrl1‘, function($scope, testProvider) { $scope.onclick1 = function() { testProvider("林炳文Evankaka"); }; }); app.controller(‘myCtrl2‘, function($scope , testProvider) { $scope.onclick2 = function() { testProvider("我到底是谁"); }; }); app.provider(‘testProvider‘, function(){ console.log(‘instance testProvider‘); var f = function(name) { alert("Hello, " + name); }; this.$get = function(){ //一定要有! return f; }; }); </script> </html>效果:
<!DOCTYPE html> <html lang="zh" ng-app="myApp"> <head> <meta charset="UTF-8"> <title>AngularJS学习</title> <script type="text/javascript" src="./1.5.3/angular.min.js"></script> </head> <body> <div ng-controller="myCtrl1"> <button ng-click="onclick1()">请点击我1</button> </div> <div ng-controller="myCtrl2"> <button ng-click="onclick2()">请点击我2</button> </div> </body> <script type="text/javascript"> var app = angular.module(‘myApp‘, []); app.controller(‘myCtrl1‘, function($scope) { /* $scope.onclick1 = function() { test("林炳文Evankaka"); };*/ }); app.controller(‘myCtrl2‘, function($scope) { /* $scope.onclick2 = function() { test("我到底是谁"); };*/ }); app.provider(‘test‘, function() { console.log(‘instance test‘); var f = function(name) { alert("Hello, " + name); }; this.$get = function() { //一定要有! return f; }; }); /*app.config(function(testProvider) { testProvider(‘I am config‘); });*/ app.config(function($provide) { $provide.provider(‘greeting‘, function() { this.$get = function() { return function(name) { alert("Hello," + name); }; }; }); /* greetingProvider(‘ff‘);*/ }); </script> </html>
<!DOCTYPE html> <html lang="zh" ng-app="myApp"> <head> <meta charset="UTF-8"> <title>AngularJS学习</title> <script type="text/javascript" src="./1.5.3/angular.min.js"></script> </head> <body> <div ng-controller="myCtrl"> <p>{{ output1 }}</p> <p>{{ output2 }}</p> <p>{{ output3 }}</p> </div> <div ng-controller="myCtrl2"> </div> </body> <script type="text/javascript"> var app = angular.module(‘myApp‘, []); app.controller(‘myCtrl‘, function($scope,testService, testFactory, testProvider) { $scope.output1 = testService.lable; $scope.output2 = testFactory.lable(); $scope.output3 = testProvider; }); app.controller(‘myCtrl2‘, function($scope,testService, testFactory, testProvider) { }); app.service(‘testService‘,function(){ console.log(‘instance testService‘); this.lable = ‘this is service‘; }); app.factory(‘testFactory‘, function () { console.log(‘instance testFactory‘); return{ lable: function(){ return ‘this is factory‘; } }; }); app.provider(‘testProvider‘, function(){ console.log(‘instance testProvider‘); this.$get = function(){ return ‘this is provider‘; }; }); </script> </html>
跟我学AngularJs:Service、Factory、Provider依赖注入使用与区别
标签:
原文地址:http://blog.csdn.net/evankaka/article/details/51114953