角度uiブートストラップモーダルを使用する指令を作成しようとしています。 $ httpリクエストが行われたときに私のコントローラからこのディレクティブを開き、リクエストが解決したらそれを閉じたいと思います。私は角度があり、ちょっと立ち往生していない。これまでに私が得たことがここにあります。
expedition.htmlコントローラ:
.controller('ExpeditionCtrl', ['$http', 'UserFactory', '$scope',
function ($http, UserFactory, $scope) {
var vm = this;
vm.totalItems;
vm.itemsPerPage = 100;
vm.currentPage = 1;
vm.pageChanged = pageChanged;
vm.content = [];
vm.loadingInstance;
vm.open;
fetchPage();
function pageChanged() {
fetchPage();
}
function fetchPage() {
$http.get('myapi?page=' + vm.currentPage + "&limit=" + vm.itemsPerPage)
.then(function(response) {
angular.extend(vm.content, response.data.content);
vm.content = response.data.content;
vm.totalItems = response.data.totalElements;
})
}
}
expedition.html:
<div class="section">
<div class="sectioncontent">
// some html
<uib-pagination total-items="vm.totalItems" ng-model="vm.currentPage" ng-change="vm.pageChanged()" items-per-page="vm.itemsPerPage"></uib-pagination>
</div>
<loading-modal loadingInstance="vm.loadingInstance" open="vm.open"></loading-modal>
</div>
</div>
loadingModal.directive.js:
.directive('loadingModal', ['$uibModal',
function($modal) {
return {
transclude: true,
restrict: 'EA',
template: '<div ng-init="open()"> Test Loading </div>',
scope: {
loadingInstance: "=",
open: "="
},
link: function(scope, element, attrs) {
scope.open = function(){
scope.loadingInstance = $modal.open({
templateUrl: 'app/templates/loadingModal.tpl.html',
controller: scope.useCtrl,
size: 'sm',
windowClass: 'app-modal-window',
backdrop: true,
});
scope.loadingInstance.result.then(function(){
scope.initialized = true;
console.log('Finished');
}, function(){
scope.initialized = true;
console.log('Modal dismissed at : ' + new Date());
});
};
}
};
}]);
loadingModal.tpl.html:
<div class="modal-body">
Loading ....
</div>
あなたの
fetchPage()
機能で
、あなたは '$ uibModalInstance.close()'(または '$ uibModalInstance.dismissを()')を呼び出している部分が含まれていない問題 –
におけるモジュールテンプレートの内容を記載してください要求が解決された後にそれらの機能の1つを呼び出す必要があります。 –
私はモーダルを開くことができなかったので、私はそれをしていませんでした。私はダイアログを開くことができませんでした。私は、ディレクティブテンプレートでng-initを使ってみました。 "テンプレート: '