欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

AngularJS中监视Scope变量以及外部调用Scope方法

程序员文章站 2023-08-27 19:30:47
在angularjs中,有时候需要监视scope中的某个变量,因为变量的改变会影响一些界面元素的显示。有时,也希望通过jquery调用scope的某个方法。 比如以下场景...

在angularjs中,有时候需要监视scope中的某个变量,因为变量的改变会影响一些界面元素的显示。有时,也希望通过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中的变量counter自增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呢的变量counter自增1。

以上所述是针对angularjs中监视scope变量以及外部调用scope方法 的相关知识,希望对大家有所帮助。