Использование $scope функций от другого контроллера в AngularJS
Я хотел бы поделиться функциями $scope одного контроллера в другом контроллере, в этом случае для диалога AngularUI.
В частности, в приведенном ниже примере я хотел бы, чтобы $scope.scopeVar был доступен в PopupCtrl.
Вот Plunkr
Разрешить код на основе комментария mlarcher здесь
main.js
angular.module('MyApp', ['ui.bootstrap']);
var MainCtrl = ['$scope', '$dialog', '$rootScope', function($scope, $dialog, $rootScope) {
$scope.myTestVar = "hello";
$scope.myOpts = {
backdrop: true,
keyboard: true,
backdropClick: true,
resolve: { MainCtrl: function() { return MainCtrl; }},
templateUrl: 'myPopup.html',
controller: 'PopupCtrl'
};
$scope.scopeVar = 'scope var string that should appear in both index.html and myPopup.html.';
$rootScope.rootScopeVar = "rootScope var string that should appear in both index.html and myPopup.html.";
$scope.openDialog = function() {
var d = $dialog.dialog($scope.myOpts);
d.open().then(function() {
$scope.scopeVar = 'scope var string should be changed after closing the popup the first time.';
$rootScope.rootScopeVar = 'rootScope var string should be changed after closing the popup the first time.';
});
};
}];
var PopupCtrl = ['$scope', 'dialog', 'MainCtrl', function ($scope, dialog, MainCtrl) {
var key;
for (key in MainCtrl) {
$scope[key] = MainCtrl[key];
}
$scope.close = function(){
dialog.close();
}
}];
index.html
<!DOCTYPE html>
<html ng-app="MyApp">
<head>
<script data-require="[email protected]" data-semver="1.1.5" src="http://code.angularjs.org/1.1.5/angular.min.js"></script>
<script data-require="[email protected]" data-semver="0.3.0" src="http://angular-ui.github.io/bootstrap/ui-bootstrap-tpls-0.3.0.min.js"></script>
<script src="script.js"></script>
<link data-require="[email protected]*" data-semver="2.3.2" rel="stylesheet" href="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" />
<link rel="stylesheet" href="style.css" />
</head>
<body ng-controller="MainCtrl">
<h4>{{scopeVar}}</h4>
<h4>{{rootScopeVar}}</h4>
<br>
<button class="btn btn-primary" type="button" data-ng-click="openDialog()" >Popup</button>
</body>
</html>
myPopup.html
<div class="modal-body">
<h4>{{scopeVar}}</h4>
<h4>{{rootScopeVar}}</h4>
</div>
<div class="modal-footer">
<button data-ng-click="close()" class="btn btn-large popupLarge" >Close</button>
</div>
Ответы
Ответ 1
У вас есть два варианта:
-
У вас может быть свойство scope, которое должно быть доступно для контроллеров, прикрепленных к rootScope
. Так что в вашем случае это будет выглядеть так:
$rootScope.scopeVar = "Data that will be available across controllers";
Однако использование этого не рекомендуется - читать Общие ошибки >
-
Services. В любое время, когда у вас есть функциональность или данные, которые необходимо повторно использовать, вам лучше работать со службами.
В вашем случае вы можете создать службу, которая хранит данные, позволяет изменять ее и передает данные тем, кто в ней нуждается. Этот ответ описывает это подробно.