我正在尝试使用ng-show显示和隐藏div。这是一个导航栏,我只想在某些视图中显示。

我有一个控制器,可以“控制”该div。在其他控制器中,我想编辑此ng-show值以隐藏或显示div(导航栏)。

我尝试了不同的方法,例如使用$rootScope,超时,$apply,工厂...,但是没有任何效果。

所以我在这里问是否有人可以帮助我。

(对不起我的英语不好)

这是我的html和js代码(最后编辑代码)

<div id="main">
    <!-- Aquí inyectamos las vistas  -->
        <div ng-controller="appCtrl" ng-show="isLogged" class="navbar navbar-fixed-top">
            <div class="container">
                <div class="navbar-header">
                    <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button>
                    <a class="navbar-brand" href="#/">Aula Virtual</a> </div>
                <div class="navbar-collapse collapse">
                    <ul class="nav navbar-nav" style="text-align: right">
                        <li class="active"><a href="#/home">Home</a></li>
                        <li><a href="#/server">Users</a></li>
                        <li><a href="#/operaciones">Operaciones</a></li>
                        <li><a href="#/about">About</a></li>
                        <li><a href="#/contact">Contact</a></li>
                    </ul>
                </div>
            </div>
            <div class="connect">
                <div class="container">
                    <p>
                        Aula Virtual para profesorado y alumnos de la universidad
                    </p>
                </div>
            </div>
        </div>
    <div ui-view></div>
    </div>




我也尝试过(ng-show =“ isLogged == false”)。

div的控制器:

.controller('appCtrl', function($scope, $rootScope) {
        console.log($scope.isLogged); //---> this shows undefined
    });




我要在其中编辑isLogged值的控制器:

cities2.controller('userCtrl',['rootScope', '$scope', '$state','$http','md5', function($rootScope, $scope, $state, $http, md5) {
    $rootScope.$apply(function(){
        $rootScope.isLogged = true;
    });




谢谢您的帮助!

最佳答案

使用服务在控制器之间共享数据是一个好习惯。

cities2.controller('appCtrl', ['$scope', 'LoggedStatus', function($scope,LoggedStatus) {
    $scope.LoggedStatus = LoggedStatus;
}]);

cities2.controller('userCtrl', ['$scope', 'LoggedStatus', function($scope,LoggedStatus) {
    $scope.LoggedStatus = LoggedStatus;
}]);

cities2.service('LoggedStatus', function() {
  return {
    isLogged: false
  }
});


更改两个控制器中的$ scope.LoggedStatus.isLogged的值将同时更改两个控制器中的值。

关于javascript - 在其他 Controller 中更改ng-show值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/36740070/

10-16 15:05