> 웹 프론트엔드 > JS 튜토리얼 > AngularJS_AngularJS에서 범위 변수를 모니터링하고 외부적으로 범위 메서드 호출

AngularJS_AngularJS에서 범위 변수를 모니터링하고 외부적으로 범위 메서드 호출

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

AngularJS에서는 변수 변경이 일부 인터페이스 요소의 표시에 영향을 미치기 때문에 범위에서 변수를 모니터링해야 하는 경우가 있습니다. 때로는 jQuery를 통해 Scope의 메서드를 호출하고 싶을 수도 있습니다.

예를 들어 다음 시나리오는 다음과 같습니다.

<div>
<button id="jQBtn">jQ Button</button>
</div>
<div id="ngSection" ng-controller="NGCtrl">
<input type="checkbox" ng-model="jQBtnState"/> Toggle jQ button state
<p>Counter: {{counter}}</p>
</div> 
로그인 후 복사

위에서 바라는 바는 다음과 같습니다.

● Scope의 jQBtnState 변수 값이 false인 경우 ID가 jQBtn인 버튼을 비활성화합니다.
● ID가 jQBtn인 버튼을 클릭하면 Scope의 메소드를 호출하여 Scope의 변수 카운터를 1씩 늘릴 수 있습니다.

다음과 같이 작성할 수 있습니다.

$('#jQBtn').on("click", function(){
console.log("JQuery button clicked");
//需要考虑的问题是:
//这里如何调用Scope中的某个方法,使Scope的的变量counter自增1
})
로그인 후 복사

...

myApp.controller("NGCtrl", function($scope){
$scope.counter = 0;
//这里,怎么让jQBtnState变量值发生变化告之外界呢?
$scope.jQBtnState = false;
$scope.jQBtnClick = function(){
$scope.counter++;
}
}) 
로그인 후 복사

실제로 $watch 메서드를 사용하여 Scope의 변수 변경 사항을 모니터링하고 변경 사항이 발생할 때 콜백 함수를 호출할 수 있습니다.

myApp.controller("NGCtrl", function($scope){
$scope.counter = 0;
$scope.jQBtnState = false;
$scope.$watch("jQBtnState", function(newVal){
$('#jQBtn').attr('disabled', newVal);
});
$scope.jQBtnClick = function(){
$scope.counter++;
}
})
로그인 후 복사

위에서 jQBtnState 변수의 값이 false이면 ID가 jQBtn인 버튼이 비활성화됩니다.

외부에서는 Scope의 메소드를 어떻게 부르나요?

--先获取Scope,然后使用$apply方法调用Scope内的方法。
$('#jQBtn').on("click", function(){
console.log("JQuery button clicked");
var scope = angular.element(ngSection).scope();
scope.$apply(function(){
scope.jQBtnClick();
});
}) 
로그인 후 복사

위에서 Scope를 구해 $apply 메소드를 사용하여 Scope에서 jQBtnClick 메소드를 호출하면 Scope의 변수 카운터가 1씩 증가합니다.

위 내용은 AngularJS에서 Scope 변수를 모니터링하고 Scope 메서드를 외부에서 호출하는 것과 관련된 지식입니다.

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