美文网首页
angularjs自定义服务

angularjs自定义服务

作者: 才気莮孒 | 来源:发表于2017-06-25 23:34 被阅读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方法定义服务'

}

});

相关文章

  • angular中的自定义服务和组件之间的通信

    1.angularjs自定义服务有几种? Provider Service Factory Value Const...

  • angularjs自定义服务

    angularjs 中可通过三种($provider,$factory,$service)方式自定义服务,以下是不...

  • AngularJS

    一、AngularJS是什么? 二、AugularJS特性 三、指令 四、自定义服务 五、路由示例路由的使用方式及...

  • AngularJS Service+Http+Select+表格

    AngularJS 服务(Service) AngularJS 中你可以创建自己的服务,或使用内建服务。 什么是服...

  • AngularJS基础学习-02

    AngularJS 服务(Service) AngularJS 中你可以创建自己的服务,或使用内建服务。 什么是服...

  • 理解angularjs之自定义指令

    理解angularjs之自定义指令尽管angularjs目前受关注程度远远低于Vuejs与reactjs,但对...

  • AngularJS 指令

    AngularJS 指令 背景 什么是AngularJS指令? 一、内置指令 二、自定义 概念 模块对象app,提...

  • angularJs Service

    在angularJs中服务是一个函数或对象,angularJs内置了30多个服务 $location服务:返回当前...

  • AngularJS之服务(Service)

    AngularJS 中你可以创建自己的服务,或使用内建服务。 首先我们来看一下AngularJS中服务是指什么? ...

  • 15. Angular的内置指令(过滤器)

    AngularJS中自定义指令处理 以ng开头的指令都是内置指令。 内置指令是AngularJS已经处理,使用内置...

网友评论

      本文标题:angularjs自定义服务

      本文链接:https://www.haomeiwen.com/subject/ahqdcxtx.html