Angularjs根本不更新ngClass

时间:2013-06-19 21:19:47

标签: angularjs angularjs-scope

我很确定这又是一件愚蠢的事。我正在学习angularjs所以我还没有得到完整的范围,但我已经到了那里。我尝试了所有的东西,并且真正搜索了我能找到的任何东西,但似乎没有任何效果。

我正在尝试在我的布局文件中执行ng-class =“...”但是表达式是在我的控制器中设置但不知何故它没有呈现。当我把它放在我的ng-view文件中时它会被渲染。我知道他只渲染文件的一部分,但我希望他也在ng-view上渲染ng-class。这是可能的还是在部分html文件中放入div更容易。

简单的html文件

<body>
<ng-view ng-class="{ 'splash': splash=='splash' }"></ng-view>
</body>

我的控制器

angular.module('xxx.splash')
    .controller('IndexCtrl', function($scope, $rootScope, config) {
        $rootScope.splash = 'splash';

        $scope.login = function(e) {
            alert('Soon. How soon? Very soon.');
        }
    });

1 个答案:

答案 0 :(得分:33)

在根范围中定义变量时,无法以在本地范围内定义变量的方式访问它。可以使用$rootScope在AngularJS模板中访问$root.<variableName>个变量,因此您的HTML文件应更改为:

<body>
<ng-view ng-class="{ 'splash': $root.splash=='splash' }"></ng-view>
</body>

您可以在此demo

中看到$scope$rootScope的差异