美文网首页我爱编程
AngularJS之服务(Service)

AngularJS之服务(Service)

作者: 聂叼叼 | 来源:发表于2018-04-16 16:01 被阅读0次

    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.htm

    2、$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

    相关文章

      网友评论

        本文标题:AngularJS之服务(Service)

        本文链接:https://www.haomeiwen.com/subject/grhekftx.html