>웹 프론트엔드 >JS 튜토리얼 >AngularJS 컨트롤러는 어떻게 서로 통신할 수 있나요?

AngularJS 컨트롤러는 어떻게 서로 통신할 수 있나요?

Susan Sarandon
Susan Sarandon원래의
2024-12-04 19:38:16560검색

How Can AngularJS Controllers Communicate With Each Other?

AngularJS 컨트롤러 교차 통신

하나의 AngularJS 컨트롤러가 다른 컨트롤러를 호출할 수 있습니까?

예, AngularJS는 컨트롤러가 서로 통신할 수 있는 여러 메커니즘을 제공합니다. 기타.

서비스 공유

효과적인 접근 방식 중 하나는 컨트롤러 간에 서비스 인스턴스를 공유하는 것입니다.

angular.module('MyApp', [])
  .service('SomeDataService', function() {
    // Shared data or methods
  })

function FirstController(SomeDataService) {
  // Use the data service...
}

function SecondController(SomeDataService) {
  // Access the same data service instance
}

이벤트 방출 범위

또 다른 방법은 범위:

function FirstController($scope) {
  $scope.$on('someEvent', function(event, args) {
    // Listen for the event
  });
}

function SecondController($scope) {
  $scope.$emit('someEvent', args);
  // Trigger the event
}

추가 통신 방법

AngularJS는 다음도 지원합니다.

  • 상위-하위 컨트롤러 통신: $scope 사용 .$parent
  • 하위-상위 컨트롤러 통신: 사용 $scope.$parent.$emit()
  • 루트 범위를 통한 컨트롤러 간 통신: $rootScope.$broadcast() 또는 $rootScope.$emit()
  • 사용자 정의 이벤트 브로드캐스팅 사용: 컨트롤러 또는 지시문 내에서 Angular의 $broadcast 및 $on 메소드 사용

위 내용은 AngularJS 컨트롤러는 어떻게 서로 통신할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.