AngularJS指令:如何更改$范围,不反映在用户界面中?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (32)

我正在尝试使用AngularJS创建一些自定义元素并将一些事件绑定到它,然后我发现$ scope.var在绑定函数中使用时不会更新UI。 这是一个简单的例子,描述了问题:

HTML:

<!doctype html>
<html ng-app="test">
  <head>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.6/angular.min.js"></script>
    <script src="script.js"></script>

  </head>
  <body>

<div ng-controller="Ctrl2">
  <span>{{result}}</span>
  <br />
  <button ng-click="a()">A</button>
  <button my-button>B</button>

</div>


  </body>
</html>

JS:

function Ctrl2($scope) {
    $scope.result = 'Click Button to change this string';
    $scope.a = function (e) {
        $scope.result = 'A';
    }
    $scope.b = function (e) {
        $scope.result = 'B';
    }
}

var mod = angular.module('test', []);

mod.directive('myButton', function () {
    return function (scope, element, attrs) {
        //change scope.result from here works
        //But not in bind functions
        //scope.result = 'B';
        element.bind('click', scope.b);
    }
});

DEMO:http://plnkr.co/edit/g3S56xez6Q90mjbFogkL?p=preview

基本上,当用户单击按钮B时(类似于按钮A上的),我将click事件绑定到my-button并想要更改。但如果我这样做,这个观点不会更新到新的$scope.resultng-click:a()$scope.result

我应该如何解决这个问题?

提问于
用户回答回答于

事件处理程序被称为“外部”Angular,因此虽然你的$scope属性将被更新,但视图不会更新,因为Angular不知道这些更改。

在你的事件处理程序的底部调用$scope.$apply()。Angular会注意到你对$scope(因为你在HTML中$watches使用的Angular设置)所做的更改{{ ... }}并更新视图。

用户回答回答于

如果销毁分配给视图的父范围,则即使在$apply()调用之后,其更改也不会以任何方式影响视图。查看示例 - 你可以通过文本输入更改视图值,但是当你单击时Destroy parent scope!,模型不再更新。

当使用Angular Bootstrap的模式时,我遇到了这个问题。我试图打开第一个范围的第二个模态。然后,我立即关闭了导致父作用域被销毁的第一个模式。

扫码关注云+社区

领取腾讯云代金券