angularjs中包含了三种创建自定义服务的方式:factory,service,provider。对于三种方式的区别,简单点来说,有下面几点:
factory
可以理解为一个function,会返回一个有方法有属性的对象;
//创建模型
var app = angular.module('myApp', []);
//通过工厂模式创建自定义服务
app.factory('myFactory', function() {
var service = {};//定义一个Object对象'
service.name = "张三";
var age;//定义一个私有化的变量
//对私有属性写getter和setter方法
service.setAge = function(newAge){
age = newAge;
}
service.getAge = function(){
return age;
}
return service;//返回这个Object对象
});
//创建控制器
app.controller('myCtrl', function($scope, myFactory) {
myFactory.setAge(20);
$scope.r =myFactory.getAge();
alert(myFactory.name);
});
service
可以理解为一个构造器,它没有返回值,通过关键字new来实例化,在AngularJS中它是单例,在需要到的时候被创建,只有在应用生命周期结束的时候(关闭浏览器)才会被清除。而controllers在不需要的时候就会被销毁了所以用它在Controller中通信或者共享数据都很合适;
var app = angular.module('myApp', []);
app.service('myService', function($http,$q) {
this.name = "service";
this.myFunc = function (x) {
return x.toString(16);//转16进制
}
this.getData = function(){
var d = $q.defer();
$http.get("ursl")//读取数据的函数。
.success(function(response) {
d.resolve(response);
})
.error(function(){
alert(0)
d.reject("error");
});
return d.promise;
}
});
app.controller('myCtrl', function($scope, myService) {
$scope.r = myService.myFunc(255);
myService.getData().then(function(data){
console.log(data);//正确时走这儿
},function(data){
alert(data)//错误时走这儿
});
});
provider
可以理解为一个Object对象,但是,确实唯一一个可以通过.config 在service加载之前进行模块范围配置的服务,它也是唯一的可以在你的控制器中访问的属性和方法是通过$get()函数返回内容。需要注意的是:在config函数里注入provider时,名字应该是:providerName+Provider,其中factory和service都是通过provider实现的。
var app = angular.module('myApp', []);
//需要注意的是:在注入provider时,名字应该是:providerName+Provider
app.config(function(myProviderProvider){
myProviderProvider.setName("大圣");
});
app.provider('myProvider', function() {
var name="";
var test={"a":1,"b":2};
//注意的是,setter方法必须是(set+变量首字母大写)格式
this.setName = function(newName){
name = newName
}
this.$get =function($http,$q){
return {
getData : function(){
var d = $q.defer();
$http.get("url")//读取数据的函数。
.success(function(response) {
d.resolve(response);
})
.error(function(){
d.reject("error");
});
return d.promise;
},
"lastName":name,
"test":test
}
}
});
app.controller('myCtrl', function($scope,myProvider) {
alert(myProvider.lastName);
alert(myProvider.test.a)
myProvider.getData().then(function(data){
//alert(data)
},function(data){
//alert(data)
});
});
对比与上面的说明,应该很容易判断出在不同的情况下需要使用的创建自定义服务的方式。
之前看过这些自定义服务的源码,看源码,对内部的结构还是比较容易理解的。但是突然找不到了,等找到了再补充。
参考博客:http://blog.csdn.net/zcl_love_wx/article/details/51404390