angularJS学习小结——service

2024-08-26 15:18

本文主要是介绍angularJS学习小结——service,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


   引言


   最近在项目中用到了关于angularJS中的服务相关的知识,在起初学习这个东西的时候就了解到这个东西在项目


中是经常被用到的,在angular中也是比较重要的一块,所以今天小编就总结一些关于service的知识。


   认识Service


   关于service我们一点都不陌生,不论实在c#中还是java中我们经常会遇到service的概念,其实service的作用


就是对外提供某种特定的功能,也就是我们经常说的“为了实现某个功能而调用哪个服务”是一样的道理,他们一般


是一个独立的模块,ng服务是这样的定义的:


   Angular services are singletons objects or functions that carry out specific tasks common to web apps.

   1、它是一个单利对象或函数,对外提供特定的功能。


   2、它与我们自己定义一个function然后在其他地方调用不同,因为服务被定义在一个模块中,所以它的作用范


围是可以被我们来管理的,ng避免全局变量污染意识是非常强的。


   自定义服务


   在angular中为我们提供了三种不同的方式来实现自定义服务,他们分别是系统内置的$provider、module中的


service和module中的factory,下面来看看如何使用这三种方式;


   1)$provide的使用


   Providers 是唯一一种你可以传进 .config() 函数的 service。当你想要在 service 对象启用之前,先进行


模块范围的配置,那就应该用 provider


 var m1 = angular.module('myApp', [], function ($provide) {$provide.provider('providerService01', function () {this.$get = function () {return {message: 'this is providerService01'}}})$provide.provider('providerService02', function () {this.$get = function () {var _name = '';var service = {};service.setName = function (name) {_name = name;}service.getName = function () {return _name}return service;}})})m1.controller('firstController', ['$scope', 'providerService01', 'providerService02', function ($scope, providerService01, providerService02) {console.log(providerService01);providerService02.setName("李四");$scope.name = providerService02.getName();}])

   我们在使用$provide的使用可以像上面这样直接在module中直接注入$provide,然后再module中依次定义多个


务,当然我们也可以利用config来完成服务的定义。


var m1=angular.module('myApp',[]);
m1.config(function($provide){$provide.provider('providerService01', function () {this.$get = function () {return {message: 'this is providerService011'}}});$provide.provider('providerService02', function () {this.$get = function () {var _name='';var service={};service.setName=function(name){_name=name;}service.getName=function(){return _name}return service;}});
})


    上面这两种实现方式达到的效果是一样的,所以我们在使用的时候可以任意选择一种来实现。


   2)factory的使用


   Factory方法直接把一个函数当成一个对象的$get 方法可以直接返回字符串,用 Factory 就是创建一个对象,


为它添加属性,然后把这个对象返回出来。你把 service 传进 controller 之后,在 controller 里这个对象里的


属性就可以通过 factory 使用了。 

var m1 = angular.module('myApp', [], function ($provide) {$provide.factory('factoryService01',function(){return{message:'this is providerServices01'}})
});

   factory的使用比$provide的使用简单一些,可以在factory直接返回已给对象,不在使用$get来实现对象的返


回。并且$factory和$provide不仅仅可以返回一个对象还可以返回一个任意的字符串。


   3)service的使用


   Service 是用"new"关键字实例化的。因此,你应该给"this"添加属性,然后 service 返回"this"。你把 


service 传进 controller 之后,在 controller 里 "this" 上的属性 就可以通过 service 来使用了   


$provide.service('service01',function(){return{message:'this is providerServices01'}})

   service和factory的使用是非常相似的,但是service是不能返回字符串的,而factory既可以返回对象也可以返回任意


的字符串。


   三者的区别:provider需要借助$get来实现,而其余的两者都不需要。series不能返回字符串,而其他的两个


都可以返回。


   服务之间的依赖关系


   我们在实现某个功能的时候也许需要多个服务相互依赖才可以完成,那么对于服务之间的关系我们就需要来管


理,例如我们在完成一个数据验证的功能,这是在jsFiddle中找的一个非常简单的小例子

var app = angular.module('MyApp', []);
app.controller('testC3',function($scope,validate){$scope.validateData = validate;
});app.factory('remoteData',function(){var data = {name:'n',value:'v'};return data;
});app.factory('validate',function(remoteData){return function(){if(remoteData.name=='n'){alert('验证通过');}};
});

    服务validate是来验证数据是否合法的功能,但是它需要依赖另外一个服务remoteData来获得数据,但是在


factory的参数中,我们可以直接传入服务remoteData,ng的依赖注入机制便帮我们做好了其他工作。不过一定要保


证这个参数的名称与服务名称一致,ng是根据名称来识别的。若参数的名次与服务名称不一致,你就必须显示的声明


一下,方式如下:


app.factory('validate',['remoteData',function(remoteDataService){return function(){if(remoteDataService.name=='n'){alert('验证通过');}};
}]);


  小结


  以上是小编在学习angularJS服务的一些总结,这些都是入门的知识,在这和大家分享一下,如果想要对服务有更


层的理解还需要我们在项目中好好的研究。

这篇关于angularJS学习小结——service的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Flutter打包APK的几种方式小结

《Flutter打包APK的几种方式小结》Flutter打包不同于RN,Flutter可以在AndroidStudio里编写Flutter代码并最终打包为APK,本篇主要阐述涉及到的几种打包方式,通... 目录前言1. android原生打包APK方式2. Flutter通过原生工程打包方式3. Futte

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Ollama Python 使用小结

《OllamaPython使用小结》Ollama提供了PythonSDK,使得开发者能够在Python环境中轻松集成和使用本地运行的模型进行自然语言处理任务,具有一定的参考价值,感兴趣的可以了解一... 目录安装 python SDK启动本地服务使用 Ollama 的 Python SDK 进行推理自定义客

java String.join()的使用小结

《javaString.join()的使用小结》String.join()是Java8引入的一个实用方法,用于将多个字符串按照指定分隔符连接成一个字符串,本文主要介绍了javaString.join... 目录1. 方法定义2. 基本用法2.1 拼接多个字符串2.2 拼接集合中的字符串3. 使用场景和示例3

Qt 中 isHidden 和 isVisible 的区别与使用小结

《Qt中isHidden和isVisible的区别与使用小结》Qt中的isHidden()和isVisible()方法都用于查询组件显示或隐藏状态,然而,它们有很大的区别,了解它们对于正确操... 目录1. 基础概念2. 区别清见3. 实际案例4. 注意事项5. 总结1. 基础概念Qt 中的 isHidd

SQL中的CASE WHEN用法小结

《SQL中的CASEWHEN用法小结》文章详细介绍了SQL中的CASEWHEN函数及其用法,包括简单CASEWHEN和CASEWHEN条件表达式两种形式,并通过多个实际场景展示了如何使用CASEWH... 目录一、简单CASE WHEN函数:二、CASE WHEN条件表达式函数三、常用场景场景1:不同状态展

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML