• [AngularJS] Services, Factories, and Providers -- Service vs Factory


    Creating a Service:

    Before actual create an angular service, first create a constructor in Javascript:

        //constructor function
        function DroidService() {
            this.name = '';
        }
    
        DroidService.prototype.speak = function () {
            return "Hi I am " + this.name;
        };

    Then you we want to use this constutor function, you need to new an instance:

        var droid = new DroidService();
        droid.name = 'r2-d2';
        console.log(droid.speak());

    What need to understand here is that, you when do new opration, under the hook, Javascript does tow thing for you:

        function DroidService() {
            // var this = {}    
            this.name = '';
           // return this;
        }

    First is var a new this object, then return this object.

    Angular service is a constructor function.

        //constructor function
        function DroidService() {
            this.name = '';
        }
    
        DroidService.prototype.speak = function () {
            return "Hi I am " + this.name;
        };
    
        angular.module('app', [])
            .service('droid', DroidService)
            .controller('DroidController', DroidController);
    
        function DroidController(droid) {
            var droidCtrl = this;
            droid.name = 'r2-d2';
            droidCtrl.message = droid.speak();
    
        }

    When you create a service in angular, it helps to 'new' the constructor (service), then inject this instance whenever you want to use it.

    Creating a Factory:

    You can create an function which return an object:

        function droidFactory() {
            function speakingPrivately() {
                return "Hi I am " + this.name;
            }
            
            return {
                name: '',
                speak: speakingPrivately
            };
        }

    This is called reaveling modular partten, because you can choose which function or props to be public or private by include those into return object. 

    Then you just need to invoke the function, you can get the object.

        var droid = droidFactory();
        droid.name = 'c3-po';
        console.log(droid.speak());

    Angular Factory is a function which return an object. (No constructor fucntion, no new opreation):

        //revealing module pattern
        function droidFactory() {
            function speakingPrivately() {
                return "Hi I am " + this.name;
            }
    
            return {
                name: '',
                speak: speakingPrivately
            };
        }
    
    
        angular.module('app', [])
            .factory('droid', droidFactory)
            .controller('DroidController', DroidController);
    
        function DroidController(droid) {
            var droidCtrl = this;
            droid.name = 'c3-po';
            droidCtrl.message = droid.speak();
        }

    When you create a factory, Angular will help to invoke the function so when you inject into controller, you will get the object back.

  • 相关阅读:
    tomcat使用不同的jdk版本 liunx 装两个jdk
    接下来自己的研究对象
    钉钉小程序开发的所有坑
    java 在web应用中获取本地目录和服务器上的目录不一致的问题
    Python2.7更新pip:UnicodeDecodeError: 'ascii' codec can't decode byte 0xb7 in position 7: ordinal not in range(128)
    vue项目中禁止移动端双击放大,双手拉大放大的方法
    JZ56 删除链表中重复的结点
    JZ55 链表中环的入口结点
    JZ54 字符流中第一个不重复的字符
    JZ53 表示数值的字符串
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5044040.html
Copyright © 2020-2023  润新知