调用方法从一个控制器到角度js中的另一个控制器

时间:2015-01-20 10:50:38

标签: javascript angularjs

我想调用从一个控制器到另一个控制器的方法。有两个控制器命名为" header"和" mainContent"。需要调用"触发方法"在"标题控制器"中,成功调用"结果方法"在mainController中。
如果该方法调用该方法应该隐藏该段落。

<div ng-controller="header">
  <p ng-show="msg">Content</p>
</div>
<div ng-controller="mainContent">
</div>


var module = angular.module("sourceViewer", ['ui.router']);
//header controller
module.controller('header', function ($scope, $location) {
      $scope.msg=true;
       $scope.trigger= function(data) { //This method should be called after the result method called in the mainContent Controller
            $scope.$on('UPDATE_CHILD', function() {
             if(data)
             $scope.msg=false;
            });

       }

});

// mainContent controller
module.controller('mainContent', function ($scope, $location, dataService) {

    $scope.user = dataService.user;
    $scope.signIn = function (user) {

        var result = dataService.login(user);
        result.success(function (data) {
            if (data.message== "success") {
                $scope.$broadcast('UPDATE_CHILD');
             //From here I want to call trigger method of header controller
            } 
        })
    };



});

3 个答案:

答案 0 :(得分:3)

你尝试过这个吗?

module.controller('header', ['$scope', '$location', '$rootScope', function ($scope, $location, $rootScope) {
              $scope.msg=true;
               $scope.trigger= function(data) { 
                  if(data)
                  $scope.msg=false;
               };

               $rootScope.$on('event:fire', $scope.trigger);

        }]);

        // mainContent controller
        module.controller('mainContent', ['$scope', '$location', 'dataService', function ($scope, $location, dataService) {

            $scope.user = dataService.user;
            $scope.signIn = function (user) {

                var result = dataService.login(user);
                result.success(function (data) {
                    if (data.message== "success") {
                      $rootScope.$broadcast('event:fire');
                    } 
                })
            };
    }]);

答案 1 :(得分:0)

您可以使用$ rootScope,如:

<div ng-controller="header">
    <p ng-show="$root.header.msg">Content</p>
</div>
<div ng-controller="mainContent">
</div>

var module = angular.module("sourceViewer", ['ui.router']);
//header controller
module.controller('header', function ($rootScope,$scope, $location) {
  $rootScope.header.msg = true;
});

// mainContent controller
module.controller('mainContent', function ($rootScope,$scope, $location, dataService) {

$scope.user = dataService.user;
$scope.signIn = function (user) {

    var result = dataService.login(user);
    result.success(function (data) {
        if (data.message== "success") {
         $rootScope.header.msg = true;
        } 
    })
};
});

答案 2 :(得分:0)

在下面的代码中,您可以看到标题Controller在mainController中调用alert

myApp = angular.module("myApp",[]);

myApp.service("myService", function(){
    showAlertBool = false;
    return {
        showAlert: function (value) {
               showAlertBool = value;
        },

        canShowAlert: function () {
            return showAlertBool;
        }
    }
});

myApp.controller("headerController", function($scope, myService){
    console.log(myService);
    $scope.clickHandler = function(){
        myService.showAlert(true);
    }
});

myApp.controller("mainController", function($scope, myService){
    console.log(myService);
    $scope.getServiceValue = function(){
        return myService.canShowAlert();
    }

    $scope.$watch("getServiceValue()", function(newValue, oldValue){
        if(newValue === true && newValue !== oldValue){
            myService.showAlert(false);
            alert("I can show Alert now!!!");
        }
    });
});

对于正常工作的代码,您可以here