Angularjs의 컨트롤러 간 통신 방법 예 요약
이 글은 AngularJS에서 구현한 컨트롤러 간의 통신 방식을 주로 소개하고 있으며, AngularJS 컨트롤러의 일반적인 통신 방식과 관련 동작 주의사항을 예시 형태로 요약 분석하였습니다. Angularjs의 컨트롤러 구현. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
Angularjs를 사용하는 개발 프로젝트에서는 매개변수 및 데이터 전송과 같은 컨트롤러 간의 통신이 비교적 일반적입니다. 컨트롤러 간의 통신은 특히 중요합니다. 두 가지 일반적인 방법이 있습니다. 첫째, 각도 서비스 방식, 둘째, 이벤트 브로드캐스팅 기반 방식, 범위 상속 기반 방식도 있습니다. 처음 두 가지 방법에 대해 먼저 이야기해 보겠습니다.
1. 각도 서비스 기반 방법: 각도에서는 서비스가 싱글톤이므로 서비스에서 개체가 생성되고 개체는 종속성 주입을 사용할 수 있습니다. 메소드는 모든 컨트롤러에서 공유됩니다. 다음 예를 참조하면 한 컨트롤러에서 서비스 객체의 값이 수정되고 다른 컨트롤러에서 수정된 값을 얻습니다.
var app = angular.module('myApp', []); app.factory('Myservice', function(){ return {}; }); //定义服务 app.controller('Ctrltest1', function($scope, 'Myservice') { $scope.change = function() { Myservice.name = $scope.test; //在第一个控制器中为服务对象赋值 }; }); app.controller('Ctrltst2', function($scope, 'Myservice') { $scope.add = function() { $scope.name = Myservice.name; //将第一个控制器中为服务对象赋的值传给第二个控制器 }; });
<p ng-controller='Ctrltest1'> <input type="text" ng-model="test" /> <p ng-click="change()">click me</p> </p> <p ng-controller='Ctrltest2'> <p ng-click="add()">my name {{name}}</p> </p>
2. 이벤트 브로드캐스트 기반 방법 이벤트 방송을 기반으로 $emit()
, $broadcaset()
및 $emit()
세 가지 메서드를 사용해야 합니다. .
1. 상위 범위 계층 구조로 사용자 정의 이벤트를 내보냅니다. $emit()
메서드, scope.$emit(name,[args,...])</code >를 사용합니다. <code>$emit()
、$broadcaset()
和$emit()
这三个方法。
1. 向父作用域层次结构发出自定义事件:使用$emit()
方法,scope.$emit(name,[args,...])
注:name是事件名,args 是0个或多个参数。
应用场景:用于子页面控制器向父页面的控制器传递参数。
2. 向子作用域层次结构广播自定义事件:
应用场景:用于父页面控制器向子页面的控制器传递参数或者同级控制器之间传递参数。
使用$broadcaset()
方法,$scope.$broadcaset(name,[args,...])
注:name是事件名,args 是0个或多个参数.
3. 使用侦听器处理自定义事件
为了处理发出或广播的事件,可以使用$on()
方法。$on()
方法将使用下面的语法:
$scope.$on(name,listener)
注:name 是将要侦听的事件的名字,listener参数是一个函数,它将接受事件作为第一个参数,接受$emit()
或者$broadcaset()
方法传递的其他所有参数作为随后的参数。$on()
方法主要用于监听$emit()
和$broadcaset()
참고:
name은 이벤트 이름이고 args는 0개 이상의 매개변수입니다.응용 시나리오:
하위 페이지 컨트롤러에서 상위 페이지 컨트롤러로 매개변수를 전달하는 데 사용됩니다. 2. 하위 범위 계층 구조에 사용자 정의 이벤트 방송:응용 시나리오:
상위 페이지 컨트롤러가 하위 페이지 컨트롤러에 매개변수를 전달하거나 형제 컨트롤러 간에 매개변수를 전달하는 데 사용됩니다.$broadcaset()
메서드인 $scope.$broadcaset(name,[args,...])
를 사용하세요.참고: name은 이벤트입니다. name, args는 0개 이상의 매개변수입니다.
3. 리스너를 사용하여 맞춤 이벤트를 처리하세요
방출되거나 브로드캐스트된 이벤트를 처리하려면 $on()
메서드를 사용할 수 있습니다. $on()
메서드는 다음 구문을 사용합니다: $scope.$on(name,listener)
참고: name은 이벤트입니다. 이름을 들을 수 있는 경우, 리스너 매개변수는 이벤트를 첫 번째 매개변수로 받아들이고 $emit()
또는 $broadcaset()</code에 의해 전달된 다른 모든 매개변수를 받아들이는 함수입니다. > 메소드를 후속 매개변수로 사용합니다. <code>$on()
메서드는 주로 $emit()
및 $broadcaset()
메서드에서 이벤트의 변경 사항을 모니터링하는 데 사용됩니다. 이 두 가지 방법 변수가 변경되면 $on() 메서드는 변수의 변경 사항을 가져옵니다.
다음 예를 참고하세요. 한 컨트롤러에서 변수의 값을 수정하면 수정된 값이 다른 컨트롤러에서 들리고 수정된 값에 따라 응답합니다.
app.controller('versiontaskCtrl', function WriteTestcaseCtrl($scope, $cookies, $rootScope, $modal, $stateParams, ui, searchVariable, currentuserversions,) { $scope.taskId = $cookies['edit_taskId']; $scope.versionid = parseInt($cookies['edit_versionId']); $scope.versionName = $cookies['edit_versionName']; $scope.version = $scope.versionid; getuserversions = function () { currentuserversions.get(function (res) { $scope.versions = res; }); }; reload = function () { getuserversions(); }; $scope.changeVersionid = function (v) { console.log(v); $scope.$broadcast('versionidChange', $scope.versionid); //向其他控制器广播$scope.versionid值的变化。 }; reload(); });
두 번째 컨트롤러는 첫 번째 컨트롤러에서 브로드캐스트 이벤트를 수신합니다.
🎜🎜app.controller('SchemeTaskEditableRowCtrl', function ($scope, $rootScope, $cookies, $filter, $http, $window, $stateParams, basetasksService, schemetasksService, UserService) { $scope.taskId = $cookies['edit_taskId']; $scope.versionid = $cookies['edit_versionId']; $scope.version = $scope.versionid; var userid = $rootScope.user.userid; $scope.schemetask = []; $scope.basetask = []; $scope.result = []; $scope.$on('versionidChange', function (event, versionid) { $scope.versionid = versionid; //监听到$scope.versionid值的变化。然后调用 $scope.schemeTask()和$scope.getUsers()这两个方法 $scope.schemeTask(); $scope.getUsers(); }); $scope.schemeTask = function () { $scope.tasks = []; $scope.schemetask = []; schemetasksService.get({version: $scope.versionid}, function (res) { $scope.schemetask_collection = res.results; //console.log($scope.schemetask_collection); $scope.schemetask_displayed = [].concat($scope.schemetask_collection); var i = 1; angular.forEach($scope.schemetask_collection, function (item) { item['director'] = "app.writetestitem" + "({taskid:" + item.id + "})"; item['number'] = i; i++; $scope.schemetask.push(item); }); $scope.tasks = $scope.schemetask; }); }; $scope.getUsers = function () { UserService.get(function (res) { $scope.users = res.results; $scope.usersDisplayed = [].concat($scope.users); $scope.itemArray = []; $scope.userArray = []; $scope.names = []; angular.forEach($scope.users, function (item) { $scope.itemArray.push(item); $scope.userArray.push(item.name + item.number); var itemname = {'name': item.name, 'number': item.number}; $scope.names.push(itemname); }); $scope.selected = $scope.users; }); }; });
위 내용은 Angularjs의 컨트롤러 간 통신 방법 예 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

Laravel을 처음부터 배우기: 컨트롤러 메소드 호출에 대한 자세한 설명 Laravel 개발에 있어서 컨트롤러는 매우 중요한 개념입니다. 컨트롤러는 모델과 뷰 사이의 브리지 역할을 하며 경로의 요청을 처리하고 해당 데이터를 표시하기 위해 뷰에 반환합니다. 컨트롤러의 메서드는 경로로 호출할 수 있습니다. 이 문서에서는 컨트롤러에서 메서드를 작성하고 호출하는 방법을 자세히 소개하고 구체적인 코드 예제를 제공합니다. 먼저 컨트롤러를 만들어야 합니다. Artisan 명령줄 도구를 사용하여 생성할 수 있습니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용
