《AngularJS》------自定义服务 provider、service、factory

2024-08-27 20:48

本文主要是介绍《AngularJS》------自定义服务 provider、service、factory,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    在AngularJS中,我们经常将通用的业务逻辑封装在服务里面,这样一来,不仅减少了代码量,而且使出错率也降低了,代码的易读性也提高了,所以说,我们经常用到了业务逻辑,或者是说持久化数据化操作应该放在自定义的服务里面,而不是Controller里面。下面我说一下provider、service、factory的定义方式还有主要区别。

    1、provider

    Providers是唯一 一种你可以传进 .config() 函数的service。当你想要在 service对象启用之前,先进行模块范围的配置,那就应该用 provider。当我们定义provider时候,我们还必须将返回对象放在this.$get=function(){}中。代码如下:

var myModule = angular.module("HelloAngular", []);
myModule.config(['providerServiceProvider',function(providerServiceProvider){providerServiceProvider.name='这是通过外部config传入的参数名字:大哥你好啊!!!!!!';
}])myModule.provider('providerService',function(){this.name='';this.$get=function(){var _name='';var serverce={};var that =this;serverce.setName=function(name){_name=name;}serverce.getName=function(){return _name;}serverce.getConfigName=function(){return that.name;}return serverce;}
});

    定义个Controller调用该服务

myModule.controller("helloAngular", ['$scope','service01','factory01','providerService',function HelloAngular($scope,service01,factory01,providerService) {providerService.setName("这是providerService服务设置的名字:美女,今晚约吗?");console.log(providerService.getName());console.log(providerService.getConfigName());}
]);

    效果图:

 

     2、service

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

myModule.service('service01',function(){var _name='';this.setName=function(name){_name=name;}this.getName=function(){return _name;};});

    Controller可以这么写

myModule.controller("helloAngular", ['$scope','service01',function HelloAngular($scope,service01) {service01.setName("这是service01服务设置的名字:美女,今晚约吗?");console.log(service01.getName());}
]);

    3、factory

    factory 方法直接把一个函数当成一个对象的$get 方法,它还可以直接返回字符串,用factory 就是创建一个对象,为它添加属性,然后把这个对象返回出来。你把service 传进 controller 之后,在controller 里这个对象里的属性就可以通过factory 使用了。代码如下:

    factory直接返回字符串,其它的两个服务不行。

myModule.factory('factory01',function(){return '你大爷的';
});

    factory定义对象,然后在对象上定义各种属性,各种方法。

myModule.factory('factory01',function(){var _name='';var serverce={};var that =this;serverce.setName=function(name){_name=name;}serverce.getName=function(){return _name;}serverce.getConfigName=function(){return that.name;}return serverce;
});

    Controller的调用我就不用再写了吧,和上面一样,相比较三种方式,定义服务的方法大同小异,只是provider方法稍微复杂了点。

     service方法与factory相比,service可以不用生命对象,它直接将某些属性和方法绑定在this上就可以,但是它不可以直接返回字符串,而factory定义的服务必须在里面定义一个对象,将某些公用的方法或者属性绑定在此对象上,然后Return回去。这就是我总结的Angular中三种自定义服务的区别,其实这三种服务还有其它定义方式,可以通过config定义,也可以直接在声明module时当第三个参数传入进去使用,本人认为使用module方法简单,所以今天只是总结了这种方法。

这篇关于《AngularJS》------自定义服务 provider、service、factory的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112745

相关文章

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT