当前位置: 移动技术网 > IT编程>脚本编程>AngularJs > AngularJS中监视Scope变量以及外部调用Scope方法

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

2018年06月17日  | 移动技术网IT编程  | 我要评论

在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方法 的相关知识,希望对大家有所帮助。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网