angular学习笔记--服务的三种定义方式

2 篇文章 0 订阅

angularjs 中可通过三种($provider,$factory,$service)方式自定义服务,以下是不同的实现形式:

// 定义module , module中注入$provide

var starterApp = angular.module('starter.controllers', [],function($provide){

// 第一种方式:使用provide的provider自定义服务

$provide.provider('getUserInfoService', function(){

this.$get = function(){

var userInfo = [{

'userName':'张三0',

'userNick':'小花0',

'age':25

},{

'userName':'张三1',

'userNick':'小花1',

'age':26

}];

return userInfo;

}

});

$provide.factory('',function(){});

$provide.service('',function(){});

});

//第二种方式 (module 的 config 方法中注入 $provide)

starterApp.config(['$provide',function($provide) {

// 使用provide的provider自定义服务(返回对象,字符串,服务,且必须通过$get方法返回)

$provide.provider('getUserAddressService', function(){

var _userAddress = '';

var service = {};

this.$get = function(){

service.setAddress = function (userAddress){

_userAddress = userAddress;

}

service.getAddress = function (){

return _userAddress;

}

return service;

}

});

// 使用provide的factory自定义服务(返回对象,服务,字符串)

$provide.factory('serviceName1', ['$http', function($http){

// var service = {};

// service.getName = function (){

//    return '张三';

// }

// return service;

//

return "啊飒飒大";

}]);

// 使用provide的service自定义服务(返回对象,服务)

$provide.service('serviceName2', ['$http', function($http){

// return {

//    'name':'aa'

// };

//可直接通过this定义方法

this.getName = function (){

return '张三';

}

}])

}]);

//第三种方式(module 的 provider、service、factory 方法   推荐第三种)

starterApp.provider('serviceName3',function(){

this.$get = function (){

return '直接通过module的provider方法定义服务';

}

});

starterApp.factory('serviceName4',function(){

return '直接通过module的factory方法定义服务';

});

starterApp.service('serviceName5',function(){

return {

'message':'直接通过module的service方法定义服务'

}

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值