角厂。如何创建工厂的新实例?

时间:2017-08-03 11:30:49

标签: javascript angularjs angular-factory

我正在尝试创建工厂的新实例,但是,它一直打印最后一个实例(因为它的单例)。 每次使用new关键字创建时,如何实现新实例? 我创建了我想在jsfiddle.net中实现的示例 感谢。

angular.module('mainModule', []);

  Crud.$inject = ['$http'];

    function Crud($http) {

        function CrudFactory(crudDTO) {
            var vm = CrudFactory;
                        vm.x = 1;
            vm.addX = addX;
            vm.getX = getX;
            vm.print = print;

            function addX(){
                vm.x +=1;
            }
            function getX(){

                return vm.x;
            }
            function print(){
                console.log(crudDTO.entity);
            }

            return vm;
        }

        return CrudFactory;
    }

    angular
        .module('mainModule')
        .factory('Crud', Crud);


    angular.module('mainModule').controller('mainCtrl', function($scope,Crud){
    var a = new Crud({entity:"test1"});
    var b = new Crud({entity:"test2"});
    //a.addX();
    //$scope.a =b.getX();
    a.print();
    b.print();
    a.print();
});

1 个答案:

答案 0 :(得分:2)

您错误地引用了它。您必须使用this而不是函数名称来引用被调用函数的实例。

相反

var vm = CrudFactory;

变化

var vm = this;

工作演示

http://jsfiddle.net/haqL7m5q/2/