• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

angularJS Provider、factory、service详解及实例代码

angularjs 搞代码 4年前 (2021-12-31) 33次浏览 已收录 0个评论

这篇文章主要介绍了angularJS Provider详解及实例代码的相关资料,需要的朋友可以参考下

factory

用 Factory 就是创建一个对象,为它添加属性,然后把这个对象返回出来。你把 service 传进 controller 之后,在 controller 里这个对象里的属性就可以通过 factory 使用了。

 app.controller('myFactoryCtrl', function($scope, myFactory){ $scope.artist = myFactory.getAr<mark style="color:transparent">来源gaodaimacom搞#^代%!码网</mark>tis(); }); app.factory('myFactory', function(){ var _artist = ''; var service = {}; service.getArtist = function(){ return _artist; } return service; }); 

service

Service 是用”new”关键字实例化的。因此,你应该给”this”添加属性,然后 service 返回”this”。你把 service 传进 controller 之后,在controller里 “this” 上的属性就可以通过 service 来使用了。

 app.controller('myFactoryCtrl', function($scope, myService){ $scope.artist = myService.getArtis(); }); app.service('myService', function(){ var _artist =''; this.getArtist = function(){ return _artist; } }); 

provider

Providers 是唯一一种你可以传进 .config() 函数的 service。当你想要在 service 对象启用之前,先进行模块范围的配置,那就应该用 provider。

 app.controller('myProviderCtrl', function($scope, myProvider){ $scope.artist = myProvider.getArtist(); $scope.data.thingFromConfig = myProvider.thingOnConfig; }); app.provider('myProvider', function(){ this._artist = ''; this.thingFromConfig = ''; this.$get = function(){ var that = this; return { getArtist: function(){ return that._artist; }, thingOnConfig: that.thingFromConfig } } }); app.config(function(myProviderProvider){ myProviderProvider.thingFromConfig = 'This was set in config()'; }); 

value和constant

 $provide.value('myValue', 10); $provide.constant('myConstant', 10); /* 二者的区别: 1. value可以被修改,constant一旦声明就无法修改 2. value不可以在config中注入,constant可以。 */ 

provider、factory、service三者的关系

 app.provider('myDate', { $get: function() { return new Date(); } }); //可以写成 app.factory('myDate', function(){ return new Date(); }); //可以写成 app.service('myDate', Date); 

总结

  1. 所有的供应商都只被实例化一次,也就说他们都是单例的
  2. 除了constant,所有的供应商都可以被装饰器(decorator)装饰
  3. value就是一个简单的可注入的值
  4. service是一个可注入的构造器
  5. factory是一个可注入的方法
  6. decorator可以修改或封装其他的供应商,当然除了constant
  7. provider是一个可配置的factory

以上就是对angularJS Provider、factory、service的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

以上就是angularJS Provider、factory、service详解及实例代码的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:angularJS Provider、factory、service详解及实例代码

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址