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 메서드를 외부에서 호출하는 것과 관련된 지식입니다.