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

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

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

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

фабрики

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

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

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

обновление

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

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

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

-фух-

4 ответов


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

проверить этот вопрос AngularJS: сервис против поставщика против фабрики

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

источник: 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
  • для большинства вещей используйте синтаксис фабрики
  • легче пойми!--4-->
  • В настоящее время с es6 "сервис" выполняется, так как он преобразуется в классы es6 лучше
  • его по существу абстрагирование бизнес-логики от контроллера
  • Если вы используете логику biz с контроллерами, то вы можете использовать только с контроллерами
  • контроллер предназначен для ввода данных о области, не обрабатывающей длительную логику biz
  • Так что происходит в приведенном выше сценарии, что сложная логика biz связана с контроллерами. Не для обработки данных. Так положите биты и части его в обслуживания или фабрику. Таким образом, ваш код является скудным и модульным.
  • услуги являются одиночными элементами

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