AngularJS 中你可以创建自己的服务,或使用内建服务。
首先我们来看一下AngularJS中服务是指什么?
在 AngularJS 中,服务是一个函数或对象,可在你的 AngularJS 应用中使用。AngularJS 内建了30 多个服务。
来看一个比较简单的内建服务: $location 服务,它可以返回当前页面的 URL 地址
$location 服务注意:$location 服务是作为一个参数传递到 controller中。如果要使用它,需要在 controller 中定义。
为什么要使用服务?
在很多服务中,比如 $location 服务,它可以使用 DOM 中存在的对象,类似 window.location 对象,但window.location 对象在 AngularJS 应用中有一定的局限性。AngularJS 会一直监控应用,处理事件变化, AngularJS 使用$location服务比使用window.location对象更好。
$location vs window.location
window.location $location.service
目的 : 允许对当前浏览器位置进行读写操作 : 允许对当前浏览器位置进行读写操作
API : 暴露一个能被读写的对象 : 暴露jquery风格的读写器
是否在AngularJS应用生命周期中和应用整合 : 否 :可获取到应用生命周期内的每一个阶段,并且和$watch整合
是否和HTML5 API的无缝整合 : 否 :是(对低级浏览器优雅降级)
和应用的上下文是否相关?否 window.location.path返回"/docroot/actual/path"是,$location.path()返回"/actual/path"
接下来看一下几个比较常用的服务:
1、$http 服务
$http 是 AngularJS 应用中最常用的服务。 服务向服务器发送请求,应用响应服务器传送过来的数据。
demo34.html welcome.htm2、$timeout 服务
AngularJS $timeout 服务对应了 JS window.setTimeout 函数。
$timeout 服务:$timeout 可用于设置单次或多次延时服务;3、$interval 服务
AngularJS $interval 服务对应了 JS window.setInterval 函数。
$interval 可用于设置始终运行的延时服务。demo36.html 这种跟上面的效果也是一样的4、$watch:持续监听数据上的变化,更新界面,如:
创建自定义服务
你可以创建自定义服务,链接到你的模块中:类似自定义指令、过滤器
自定义指令使用dircetive关键字,自定义过滤器是使用filter关键字,自定义服务是使用service关键字。如下,自定义个个将255转换为16进制数的服务,可以理解这个服务是一个功能函数。
demo37.html过滤器中,使用自定义服务
当你创建了自定义服务,并连接到你的应用上后,你可以在控制器,指令,过滤器或其他服务中使用它。
demo38.html
网友评论