angular的服务小总结

自定义服务的作者原文:http://blog.csdn.net/zcl_love_wx/article/details/51404390
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="js/angular/angular.min.js" type="text/javascript"></script>
</head>
<body ng-app="myApp" ng-controller="myCtrl">
    <!--location服务:返回当前页面的地址,需注意location服务是作为一个参数传递到 controller ,若使用需在controller中定义 -->
    <div class="oneBox">
        <p>当前页面的url:</p>
        <h3>{{myUrl}}</h3>
        <p>该实例使用了内建的$location服务获取当前页面的url</p>
    </div>

    <!--http服务:服务向服务器发送请求,应用响应服务器传来的数据-->
    <div class="twoBox">
        <p>欢迎信息:</p>
        <h3>{{myWelcome}}</h3>
        <p>$http服务向服务器请求信息,返回的值放入变量"myWelcome"</p>
    </div>

    <!--$timeout服务:延迟几秒执行代码-->
    <div class="threeBox">
        <p>{{myHead}}</p>
    </div>

    <!--$interval服务:间隔几秒执行代码-->
    <div class="fourBox">
        <p>{{theTime}}</p>
    </div>

    <!--自定义服务的三种方式:factory service provider-->
     <!--factory方式创建的服务,作用就是返回一个有属性有方法的对象,相当于: var f=myFactory();-->
    <div class="fiveBox">
        <p>{{facText}}</p>
    </div>

    <script>
        var app=angular.module('myApp',[]);
        app.controller('myCtrl',function($scope,$location,$http,$timeout,$interval,myFactory) {
            $scope.myUrl = $location.absUrl();

            $http.get("include.html").then(function(response){
                $scope.myWelcome = response.data;
            });

            $scope.myHead="hello World!!"
            $timeout(function (){
                $scope.myHead ="how are you today??"
            },2000);

            /*$scope.theTime = new Date().toLocaleDateString();*/
            $interval(function (){
                $scope.theTime = new Date().toLocaleDateString();
            },5000);

            /*factory*/
            myFactory.setAge(20);
            $scope.facText=myFactory.getAge();
            alert(myFactory.name);

        })
        //通过工厂模式创建自定义服务
        app.factory('myFactory',function(){
            var service = {}; //定义一个object对象
            service.name = '张三';
            var age;//定义一个私有化的变量,对私有属性写gettersetter方法
            service.setAge = function(newAge){
                age = newAge;
            }
            service.getAge=function(){
                return age;
            }
            return service;//返回这个object对象
        });
    </script>
<!--
    angular分层:
    1>.dao:就是model,主要写与数据库交互数据的一层,angular主要写ajax
    2>.service:主要写逻辑代码的,angular里也可以持久化数据(充当数据容器),以供不同的controller使用;
    3>.controller:即控制层,angular就是写控制器,这里尽量不要写不必要的逻辑,尽量在service;_
-->
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值