1

我正在尝试绑定到控制器范围内的布尔变量,以指示是否应显示加载动画。但是,以下代码不起作用。里面的函数$timeout运行了,但是视图没有更新。

当我使用 chrome 角度扩展检查范围时,我看到它ctrl.loadingtrue.

这是因为布尔值是 javascript 中的值类型,而不是引用类型?

我的猜测是视图实际上是绑定到的true,而不是绑定到会改变的布尔值的位置。

如何让视图绑定到变量,而不是绑定到变量最初的值?

控制器:

function TestController($scope,$timeout){
    "use strict";

    var loading=true;

    $timeout(function(){
        loading=false;
    }, 1000);

    return {
        loading:loading
    }

}

模板:

<div>
    <h1 ng-show="ctrl.loading">Loading</h1>
    <h1 ng-hide="ctrl.loading">Not Loading</h1>
</div>

上面的代码只是一个例子,实际上我会在get请求wq返回后设置值。

$http.get().then(function() {
    loading=false;
}, function() {
    loading=false;
})

但效果是一样的。

4

1 回答 1

3

loading错误地绑定了变量。您需要将该变量注册loading$scopethis变量。请参阅以下工作示例:

var app = angular.module("sa", []);

app.controller("TestController", TestController);

function TestController($scope, $timeout) {
  "use strict";
  var vm = this;

  vm.loading = true;

  $timeout(function() {
    vm.loading = false;
  }, 2000);

}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>


<div ng-app="sa" ng-controller="TestController as ctrl">
  <h1 ng-show="ctrl.loading">Loading</h1>
  <h1 ng-hide="ctrl.loading">Not Loading</h1>
</div>

此外,控制器中的返回块没有用。

编辑

现在,我明白你的问题了。这是我第一次看到这种从控制器返回的功能。经过半个小时的研究,我发现你不能期望一个原始类型在 Javascript 中通过引用传递。你需要使用一些对象。

查看范围继承问题以获得要点:https ://github.com/angular/angular.js/wiki/Understanding-Scopes

要解决此问题,您可以更改代码,如下所示:

var app = angular.module("sa", []);

app.controller("TestController", TestController);

function TestController($scope, $timeout) {
  "use strict";
  var myData = {};

  myData.loading = true;

  $timeout(function() {
    myData.loading = false;
  }, 2000);

  return {
    myData: myData
  };
}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>

<div ng-app="sa" ng-controller="TestController as ctrl">
  <h1 ng-show="ctrl.myData.loading">Loading</h1>
  <h1 ng-hide="ctrl.myData.loading">Not Loading</h1>
</div>

于 2016-07-22T04:44:24.483 回答