次の angular.ui Modalの例は、後で関数として作成される aのmodalInstance
呼び出しを示しています。ModalIntanceCtrl
var ModalDemoCtrl = function ($scope, $modal, $log) {
$scope.items = ['item1', 'item2', 'item3'];
$scope.open = function () {
var modalInstance = $modal.open({
templateUrl: 'myModalContent.html',
controller: ModalInstanceCtrl,
resolve: {
items: function () {
return $scope.items;
}
}
});
modalInstance.result.then(function (selectedItem) {
$scope.selected = selectedItem;
}, function () {
$log.info('Modal dismissed at: ' + new Date());
});
};
};
var ModalInstanceCtrl = function ($scope, $modalInstance, items) {
$scope.items = items;
$scope.selected = {
item: $scope.items[0]
};
$scope.ok = function () {
$modalInstance.close($scope.selected.item);
};
$scope.cancel = function () {
$modalInstance.dismiss('cancel');
};
};
2 つの質問/問題があります。
ドキュメントでは、別の方法でコントローラーを作成することをお勧めします (縮小の問題のため)。たとえば、次のようになります。
myApp.controller('GreetingCtrl', ['$scope', function($scope) { $scope.greeting = 'Hola!'; }]);
しかし、このようにコントローラーを作成した場合、modalInstance にどのように挿入できますか?
- ここで呼び出すコントローラーは Modal Instance コントローラーではありませんが、私の global
loginCtrl
です。これは問題ですか? どうにかして loginCtrl をサブクラス化するか、ModalInstanceCtrl から呼び出す必要がありますか? もしそうなら - どのように正確に?
これについてのガイダンスと明確化を喜んでいたします。ありがとう!