自定义服务

  • 自定义服务和自定义指令,自定义过滤器写法类似,一共有 三种关键字 定义服务

  • 使用服务必须注入,使用原生的服务注入方式是"$" + 原生服务名称。而自定义服务方式是将服务名称直接注入

    1. 通过service关键字自定义服务
<body ng-app = "app" ng-controller = "wmxController">

<p>{{said}}</p>

<script src="angular.js"></script>

<script>
    var app = angular.module('app',[]);

    //使用自定义服务:先注入自定义服务wmxService
    app.controller('wmxController',['$scope','wmxService',function ($scope,wmxService) {

        //调用服务的方法
        wmxService.say('我是调用后传递的参数');
        
        //接受函数的返回值
        $scope.said =  wmxService.say('接受函数的返回值');
    }]);
    
//    通过service关键字自定义服务
     // 参数一:自定义服务的名称
     // 参数二:回调的方法
     // this代表当前作用域(wmxService的对象)

    app.service('wmxService',function () {

        //可传递参数,也可不传递参数
        this.say = function (args) {
            alert(args);

            //也可以有返回值
            return args;
        }
    })
</script>
</body>
    1. 通过factory关键字自定义服务1 (直接把函数返回出去)
<body ng-app = "app" ng-controller = "wmxController">

<p>{{data}}</p>

<script src="angular.js"></script>

<script>
    
    var app = angular.module('app',[]);
    
    //注入自定义服务
    app.controller('wmxController',['$scope','wmxService',function ($scope,wmxService) {
        //调用自定义服务的方法,并且使用它的返回值
        $scope.data = wmxService('我是调用自定义服务后的数据');
    }]);
    
    //自定义服务:关键字factory
    app.factory('wmxService',function () {
        return function (args) {
            alert('我是自定义服务的数据');
            return args;
        }
    })
</script>
</body>
    1. 通过factory关键字自定义服务2 (返回一个函数名出去)
<body ng-app = "app" ng-controller = "wmxController">

<p>{{data}}</p>

<script src="angular.js"></script>

<script>

    var app = angular.module('app',[]);

    //注入自定义服务
    app.controller('wmxController',['$scope','wmxService',function ($scope,wmxService) {

        //调用自定义服务的方法,并且使用它的返回值
        $scope.data = wmxService.myTimer('我是调用之后的数据');

    }]);

    //自定义服务:关键字factory
    app.factory('wmxService',function () {

       //无法直接返回该函数,所以巧妙的使用了下面的方法返回出去
        function showDate(args) {
            alert('返回自定义服务中的数据');
            return args;
        }

        return{
            //key:value形式返回(取两个别名)
            myTimer:showDate
        }
    })
</script>
</body>
    1. 通过value关键字自定义服务
    • 该服务的作用是使用 angular 定义常量
    • 通过 const 定义的是常量,是不允许修改的
const wmx = 100;
//后面不能对wmx这个常量值进行修改
<body ng-app = "app" ng-controller = "wmxController">

<p>{{data}}</p>

<script src="angular.js"></script>
<script>

    var app = angular.module('app',[]);

    //注入自定义服务
    app.controller('wmxController',['$scope','username',function ($scope,username) {
        $scope.data = username;
    }]);

    //自定义服务:关键字factory
    /**
     * 相当于定义了 const username='wmx';
     * username只能永远等于wmx,不能够修改
     * 参数一:服务名称,同时也是常量,别名为username
     * 参数二:常量值为wmx
     */
   app.value('username','wmx');

</script>
</body>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 我们可以通过factory,service,value这三种方式来自定义服务。 自定义服务与我们之前学的自定义指令...
    不要和我名字一样阅读 887评论 0 11
  • 什么是跨域 不同域名之间进行数据访问,默认情况下是不允许的。 是谁导致了跨域 是浏览器导致了跨域,为了数据的安全。...
    西巴撸阅读 827评论 0 4
  • 注意点:使用服务之前,必须要注入才能使用。value:其表现方式是服务,但可以本质上把他当作是一个常量。(可以用来...
    daisx阅读 244评论 0 0
  • 什么是服务? 服务就是功能。angular在一开始就帮我们定义一些功能,我们可以使用这些功能。都是一个方法或者一个...
    MGd阅读 768评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139