AngularJS: что такое фабрика?


Я много работал над Angular.js и в целом я считаю, что это интересная и мощная структура.

Я знаю, что было много дискуссий о сервисах против фабрик против поставщиков против ценностей, но я все еще довольно смущен тем, что Factory есть.

фабрика была определена в других обсуждениях StackOverflow следующим образом:

фабрики

синтаксис: module.factory( 'factoryName', function ); результат: при объявлении factoryName в качестве вводимого аргумента вам будет предоставлено значение, которое возвращается при вызове ссылки на функцию, переданной модулю.фабрика.

Я нахожу это объяснение очень трудным для понимания, и это не увеличивает мое понимание того, что такое фабрика.

у кого-нибудь есть какие-либо объяснения или примеры из реальной жизни, чтобы поделиться о том, что именно a Factory и почему вы должны использовать его вместо Service,Provider, или другие?

обновление

A serviceсодержит ссылку любой объект.

A factoryфункция который возвращает объект

A providerфункция который возвращает функции

-фух -

4 90

4 ответа:

насколько я понимаю, они все практически одинаковы. Основные различия заключаются в их сложности. Поставщики настраиваются во время выполнения, фабрики немного более надежны, а службы-самая простая форма.

проверить этот вопрос автор: Служба против поставщика против завода

кроме этого суть может быть полезно в понимании тонких различий.

источник: https://groups.google.com/forum/#! тема / угловая/hVrkvaHGOfc

jsFiddle: http://jsfiddle.net/pkozlowski_opensource/PxdSP/14/

автор: Павел Козловский

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

//service style, probably the simplest one
myApp.service('helloWorldFromService', function() {
    this.sayHello = function() {
        return "Hello, World!";
    };
});

//factory style, more involved but more sophisticated
myApp.factory('helloWorldFromFactory', function() {
    return {
        sayHello: function() {
            return "Hello, World!";
        }
    };
});

//provider style, full blown, configurable version     
myApp.provider('helloWorld', function() {
    // In the provider function, you cannot inject any
    // service or factory. This can only be done at the
    // "$get" method.

    this.name = 'Default';

    this.$get = function() {
        var name = this.name;
        return {
            sayHello: function() {
                return "Hello, " + name + "!";
            }
        };
    };

    this.setName = function(name) {
        this.name = name;
    };
});

//hey, we can configure a provider!            
myApp.config(function(helloWorldProvider){
    helloWorldProvider.setName('World');
});


function MyCtrl($scope, helloWorld, helloWorldFromFactory, helloWorldFromService) {

    $scope.hellos = [
        helloWorld.sayHello(),
        helloWorldFromFactory.sayHello(),
        helloWorldFromService.sayHello()];
}​

одно главное отличие я вижу, что вы можете запустить пользовательский код на заводе. Но, в сервисе, происходит только создание объекта.

myJs.factory('Factory', function() {

    //Write custom code here

    return {
            Hello: function() {
            return "Hello, World!"
        }
    };
});

мои два цента на эту тему. Я очень Новичок и просто понимаю Angular JS, и это было одной из вещей, которые меня очень смутили, и поэтому я изучил ее несколько подробно. Я делал заметки для дачи интервью, и это может быть полезно для других.

  • сервис и фабрика делают то же самое по-разному
  • оба injectibles
  • для большинства вещей используйте фабричный синтаксис
  • легче поймите
  • В настоящее время с es6 "сервис" делается, так как он преобразуется в классы es6 лучше
  • его по существу абстрагирование от бизнес-логики контроллера
  • Если вы используете логику biz с контроллерами, то вы можете использовать только с контроллерами
  • контроллер предназначен для размещения данных в области, не обрабатывающей длительную логику biz
  • Итак, что происходит в приведенном выше сценарии, так это то, что сложная логика biz связана с контроллерами. Не для обработки данных. Так положите биты и части его в обслуживания или фабрику. Таким образом, ваш код является бережливым и модульным.
  • услуги являются одиночными элементами

службы-это в основном объекты, в которых вы описываете класс конструктора объекта. Где-то глубоко внутри структуры, объекта.вызывается функция create (), а затем вы можете использовать службу, вызывая ее объект и методы с помощью контроллера. Фабрика, с другой стороны, не создает объект по умолчанию и, следовательно, требует, чтобы вы вернули все расположение объекта, как только вы закончите определять все атрибуты и методы.