> 웹 프론트엔드 > JS 튜토리얼 > AngularJS_AngularJS에서 팩토리와 서비스를 사용하는 방법 소개

AngularJS_AngularJS에서 팩토리와 서비스를 사용하는 방법 소개

WBOY
풀어 주다: 2016-05-16 15:54:33
원래의
1146명이 탐색했습니다.

AngularJS는 서비스를 사용하는 아키텍처에서 "관심사 분리" 개념을 지원합니다. 서비스는 JavaScript 기능이며 하나의 특정 작업만 수행합니다. 이는 또한 유지 관리 및 테스트를 위해 별도의 엔터티를 만듭니다. 컨트롤러, 필터는 이를 요구사항의 기초로 호출할 수 있습니다. 서비스는 일반적으로 AngularJS의 종속성 주입 메커니즘을 사용하여 주입됩니다.

AngularJS는 $http, $route, $window, $location 등과 같은 다양한 내장 서비스를 제공합니다. 각 서비스는 특정 작업을 담당합니다. 예를 들어 $http는 서버에서 데이터를 가져오기 위해 AJAX 호출을 생성하는 데 사용됩니다. $route는 라우팅 정보 등을 정의하는 데 사용됩니다. 내장 서비스에는 항상 $ 기호가 앞에 붙습니다.

서비스를 만드는 방법에는 두 가지가 있습니다.

  1. 공장
  2. 서비스

팩토리 메소드 사용

팩토리 메소드를 사용하면 먼저 팩토리를 정의한 다음 여기에 메소드를 할당합니다.

   var mainApp = angular.module("mainApp", []);
   mainApp.factory('MathService', function() {   
     var factory = {}; 
     factory.multiply = function(a, b) {
      return a * b 
     }
     return factory;
   }); 

로그인 후 복사

서비스 이용방법

서비스 메소드를 사용하여 서비스를 정의한 후 메소드를 할당합니다. 또한 이미 사용 가능한 서비스를 주입합니다.

mainApp.service('CalcService', function(MathService){
  this.square = function(a) { 
 return MathService.multiply(a,a); 
 }
});

로그인 후 복사

다음 예에서는 위의 모든 명령을 보여줍니다.
testAngularJS.html



  Angular JS Forms


  

AngularJS Sample Application

Enter a number:

Result: {{result}}

<script> var mainApp = angular.module(&quot;mainApp&quot;, []); mainApp.factory('MathService', function() { var factory = {}; factory.multiply = function(a, b) { return a * b } return factory; }); mainApp.service('CalcService', function(MathService){ this.square = function(a) { return MathService.multiply(a,a); } }); mainApp.controller('CalcController', function($scope, CalcService) { $scope.square = function() { $scope.result = CalcService.square($scope.number); } }); </script>
로그인 후 복사

결과

웹 브라우저에서 textAngularJS.html을 엽니다. 아래 결과를 참조하세요.

2015617105555351.jpg (560×429)

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿