AngularJs: $watch 监听作用域变化

 angjularjs中,有些事件不是浏览器触发的,是由模型中数据的改变触发的。通过这种功能,可以对模型(model)的改变做出响应,而无须在所有值可能变化的位置添加代码。该功能是非常有用的,因为模型中的数据通常可能会使用多种方式进行改变,用户输入、服务更新等。

为了添加处理作用域值变化的功能,可以使用angjularjs中内置的$watch功能为作用域中的变量添加$watch。$scope有个$watch方法,可以监听指定的模型的改变,一旦模型改变则触发(执行)传入其中的方法,该方法接收三个参数,如下

$scope.$watch('watchExpression' , function(newValue,oldValue){  }, bool值指示是否监听的是对象),

watchExpression 是将要监视的作用域中的表达式。该表达式将在所有$digest()中调用,并将返回被监视的值。function是一个在watchExpression 值改变成新值时调用的函数。如果watchExpression 修改为一个曾经设置过的值,那么不会调用function。

下面代码展示一个在作用域变量app.settings.asideFolded上添加$watch的示例:

 $scope.$watch('app.settings.asideFolded', function () {
    if ($scope.app.settings.asideFolded) {
       
        $scope.content_width =  $window.innerWidth - 400 - 50 - 64-134+100;
         console.log( $scope.content_width);
    }
    else{
       $scope.content_width =  $window.innerWidth - 400 - 50 - 64-134;
         console.log( $scope.content_width);
    }
  
}, true);
上述方法,可以根据 作用域变量app.settings.asideFolded值的变化来改变模型作用域 content_width 值的变化。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Web魔法师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值