1

我正在使用 controllerAs 语法,并且由于某种原因,在 $interval 中更新控制器的字段时,它不会正确显示/隐藏视图中的元素。我使用 Angular 的 UI 路由器。

这个问题最好用我认为的代码来描述,所以请原谅代码转储。

我的状态(“refreshLogs”只是一个调用 logService 以获取更新日志的函数):

angular.module('portal')
.config(function ($stateProvider, $urlRouterProvider) {
    $stateProvider
         .state('logs', {
             'abstract': true,
             views: {
                 "@": { template: '<div ui-view></div>' }
             }
         })
        .state('logs.view', {
            url: '/logs/:id',
            resolve: {
                log: function ($stateParams, logService) {
                    return logService.getLog($stateParams.id);
                },
                refreshLog: function ($stateParams, logService) {
                    var id = $stateParams.id

                    var fn = function (id) {
                        return logService.getLog(id)
                    };

                    return function() { return fn(id) }
                }
            },
            templateUrl: '/app/logs/viewlog.html',
            controller: 'logController',
            controllerAs: 'vm'
        })
});

我的控制器:

angular.module('portal.controllers')
.controller('logController', function ($state, log, refreshLog, $scope, $interval) {
    var vm = this;
    vm.log = log;

    vm.refreshTimer = $interval(function () {
        refreshLog().then(function (data) {
            vm.log = data;
        })
    }, 15000);

    $scope.$on("$destroy", function () {
        if (angular.isDefined(vm.refreshTimer)) {
            $interval.cancel(vm.refreshTimer);
        }
    });
});

最后是视图:

<div ng-show="{{ vm.log != null }}">
    <div class="page-header">
        <h1>{{ vm.log.JobType }} ({{ vm.log.JobResult }})</h1>
    </div>

    Parameters: {{ vm.log.JobParameters }}

<pre>{{ vm.log.Content }}</pre>
</div>

<div ng-show="{{ vm.log == null }}">
    <div class="page-header">
        <h1>Waiting for log...</h1>
    </div>
</div>

它会在 DOM 更新中显示“ng-show”值,但不会根据该值显示/隐藏元素。我在 Chrome 中检查了 DOM,我看到了这一点(添加星号以强调):

<div ui-view="" class="ng-scope"><div ng-show="**false**" class="ng-binding ng-scope ng-hide">
    <div class="page-header">
        <h1 class="ng-binding"> ()</h1>
    </div>

    Parameters: 

<pre class="ng-binding"></pre>
</div>

<div ng-show="**true**" class="ng-scope">
    <div class="page-header">
        <h1>Waiting for log...</h1>
    </div>
</div></div>

一开始是正确的,并且显示了正确的 div。几秒钟后,日志被刷新,“vm.log”变量被设置为一个非空值(我知道这是因为我在分配这个值的 JS 代码中设置了一个断点,它看起来是正确的)。之后,我再次检查 DOM 并看到:

<div ui-view="" class="ng-scope"><div ng-show="**true**" class="ng-binding ng-scope ng-hide">
    <div class="page-header">
        <h1 class="ng-binding">...</h1>
    </div>
...
</pre>
</div>

<div ng-show="**false**" class="ng-scope">
    <div class="page-header">
        <h1>Waiting for log...</h1>
    </div>
</div></div>

注意显示正确值的“ng-show”属性。因此,表达式显然已被重新评估。但是,旧的“等待日志...”标题仍然显示,并且第一个 div 没有显示(并且它仍然应用了“ng-hide”css 类)。

我在这里想念什么?

4

1 回答 1

1

正如 Ranjith S 在评论中指出的那样,问题出在“ng-show”绑定中!那里不应该有 {{ ... }}。去掉括号解决了这个问题。

于 2015-11-25T08:54:51.547 回答