Angular服务是一个由服务工厂创建的单例对象。这些服务工厂是由 service provider 依次创建的。而service providers是构造函数。它们必须包含一个$get属性用于在实例化的时候返回服务工厂。

当你请求一个服务,$injector负责找到正确的service provider,然后将它实例化得到service factory,并调用service factory的 $get 方法来得到服务的实例。

  • provider(provider) - 使用$injector来注册一个 service provider 。
  • constant(obj) - 注册一个只有providers 和 services 可以访问的 值或对象。
  • value(obj) - 注册一个只有services 可以访问的 值或对象。
  • factory(fn) - 注册一个 service factory 方法,该方法被包裹在 provider 对象当中,并通过 $get 属性来返回这个 factory 方法。
  • service(class) - 注册一个构造方法,它是一个被包裹在 service provider 对象中的类,然后通过 $get 属性来使用该构造方法实例化一个新的对象。

provider(name, provider);

参数 类型 详细
name string

实例(也就是service factory)名称。记住:它的 provider 需要通过 name + 'Provider' 来访问。

provider Object/function()

如果这个 provider 是:

  • 对象: 那么它应该有一个 $get 方法。 这个 $get 方法会在一个实例需要被创建的时候使用$injector.invoke() 来调用。
  • 构造函数: 那么它会使用 $injector.instantiate() 来创建一个provider 的实例,并以对象的形式返回。

factory(name, $getFn);

注册一个service factory,它用于返回一个service 的实例。这是一个注册service factory的简单的写法,因为它的provider 仅仅包含一个 $get 属性。如果你不需要在provider中配置你的 service ,那你可以使用它。

参数 类型 详细
name string

实例的名称

$getFn function()

创建实例的$get方法。 本质来说这是一个$provide.provider(name, {$get: $getFn})的简写法。

service(name, constructor);

注册一个构造方法, 它会通过new方法来创建service实例。 这也是一个$provide.provider(name, {$get: $getFn})的简写法,但这里$getFn是一个构造函数,然后通过new来返回服务的实例。

如果你将你的服务定义为一个type或class,你应该使用$provide.service(class)。

value(name, value);

通过 $injector 注册一个value service,它可以是一个字符串、数值、数组、对象或者方法。该值实际上也是通过它的provider的$get属性,一个没有参数的方法来返回的value service。

它跟constant services很像,但不同点在于他们不能被注入到模块的配置方法中。

AngularJS服务中serivce,factory,provider的区别的更多相关文章

  1. AngularJS 1.x系列:AngularJS服务-Service、Factory、Provider、Value及Constant(5)

    1. AngularJS服务 AngularJS可注入类型包括:Service.Factory.Provider.Value及Constant. 2. Service AngularJS Servic ...

  2. angularJS 服务-$provide里factory、service方法

    当你初试 Angular 时,很自然地就会往 controller 和 scope 里堆满不必要的逻辑.一定要早点意识到,controller 这一层应该很薄:也就是说,应用里大部分的业务逻辑和持久化 ...

  3. AngularJS服务

    在使用AngularJS的路由管理和控制视图加载的时候,当新的视图加载进来,原有视图的控制器会被销毁,这是出于内存占用和性能的考虑.服务提供了一种能在应用的整个生命周期内保持和共享数据的方法,它能够在 ...

  4. AngularJS 1.x系列:AngularJS服务-Service

    1. AngularJS服务 AngularJS可注入类型包括:Service.Factory.Provider.Value及Constant. 2. Service AngularJS Servic ...

  5. 【AngularJS中的自定义服务service VS factory VS provider】---它们的区别,你知道么?

    在介绍AngularJS自定义服务之前,我们先来了解一下AngularJS~ 学过HTML的人都知道,HTML是一门很好的伪静态文本展示设计的声明式语言,但是,要构建WEB应用的话它就显得乏力了. 而 ...

  6. AngularJS中的Provider们:Service和Factory等的区别

    引言 看了很多文章可能还是不太说得出AngularJS中的几个创建供应商(provider)的方法(factory(),service(),provider())到底有啥区别,啥时候该用啥,之前一直傻 ...

  7. AngularJS 中的 factory、 service 和 provider区别,简单易懂

    转自:http://blog.csdn.net/ywl570717586/article/details/51306176 初学 AngularJS 时, 肯定会对其提供 factory . serv ...

  8. [译]AngularJS中几种Providers(Factory, Service, Provider)的区别

    原文: http://blog.xebia.com/2013/09/01/differences-between-providers-in-angularjs/ 什么是Provider? Angula ...

  9. angularJs 自定义服务 provide 与 factory 的区别

    <!DOCTYPE html> <html lang="en" ng-app="myApp"> <head> <met ...

随机推荐

  1. 小菜鸟学 Spring-bean scope (一)

    this information below just for study record of mine. 默认情况下:Spring 创建singleton bean 以便于错误能够被发现. 延迟加载 ...

  2. bootstrap_UI

  3. poj 3070 矩阵快速幂模板

    题意:求fibonacci数列第n项 #include "iostream" #include "vector" #include "cstring& ...

  4. 洛谷P1755 斐波那契的拆分

    题目背景 无 题目描述 已知任意一个正整数都可以拆分为若干个斐波纳契数,现在,让你求出n的拆分方法 输入输出格式 输入格式: 一个数t,表示有t组数据 接下来t行,每行一个数n(如题) 输出格式: t ...

  5. 在excel批量更改单元格类型后的批量刷新显示

    把E的东西变成完整显示 解决办法: 选中所需要更改的整列数据------>菜单栏的数据选项------>分列

  6. FluentData,它是一个轻量级框架,关注性能和易用性。

    http://www.cnblogs.com/zengxiangzhan/p/3250105.html FluentData,它是一个轻量级框架,关注性能和易用性. 下载地址:FlunenData.M ...

  7. sprintf

    功能:将数据格式化到字符串中 原型:int sprintf( char *buffer, const char *format, [ argument] … );返回值是这个字符串的长度 上次我企图这 ...

  8. frameset用法

    <html> <frameset rows="15%,*" border="1" frameborder="1" scro ...

  9. yii 10.16

    什么是框架? a)         框架就是一个半成品,一个帮助我们完成业务流程的程序 b)        框架融合了很多的功能,但是不会给我们具体功能模块 c)         我们需要在框架的基础 ...

  10. apache-ab并发负载压力测试(转)

    ab命令原理 Apache的ab命令模拟多线程并发请求,测试服务器负载压力,也可以测试nginx.lighthttp.IIS等其它Web服务器的压力. ab命令对发出负载的计算机要求很低,既不会占用很 ...