JavaScript/JQuery

BootStrap modal 2개 띄웠을 때 hidden.bs.modal event 처리

BBB.OOO 2022. 8. 16. 16:39
반응형

modal id 값은 각각 아래와 같다.

1. manageDnisDialog

2. manageDnisLicenceCountDialog

레이어 팝업창을 2개 띄우기 위해 jquery ajax를 사용하여 Controller 에서 html 코드를 받아온 후 modal 태그에 직접 넣었다.

// 첫번째 modal 레이어 팝업
$.ajax({
    cache : false,
    type : 'POST',
    dataType : "html",
    url : menu_href,
    data : {
        dnis : dnis,
        action_type : action_type
    },
    success : function(data) {
        $('#manageDnisDialog').html(data); //html data가 담길 target div
        $('#manageDnisDialog').modal({
            keyboard : false,
            show : true
        }); //modal 오픈
    },
    error : function(xhr, status, error) {
        alert(xhr.responseText);//ajax 오류 메세지
        location.reload();
    }
});

//두번째 modal 레이어 팝업
$.ajax({
    url: controller의 requestMapping url',
    type: 'POST',
    dataType: 'html',
    data: { dnis: $("#dnis").val(), site_code: $("#site_code").val() },
    success: function(result) {
        $("#manageDnisLicenceCountDialog").html(result);
        $('#manageDnisLicenceCountDialog').modal({ keyboard : false, show : true });
    }
})

위 이미지와 같이 id가 manageDnisDialog 인 곳에 .html()을 통해 html 코드를 직접 넣었다.

 

마지막 레이어 팝업창을 닫았을 경우 해당 페이지 리로드를 진행한다.

 

//modal이 닫힐때 event
$("#manageDnisDialog").on('hidden.bs.modal', function() {
    //현재 페이지 갱신
    location.reload();
});

 

하지만 예상과는 달리 2번째 레이어 팝업창인 manageDnisLicenceCountDialog를 닫았을 경우에도 위 이벤트가 발생해버린다.

제대로된 해결 방법은 아니지만 모든 팝업창이 닫혔을 경우에만 리로드 하기 위해선 아래와 같이 코드를 추가해줘야 한다.

 

//modal이 닫힐때 event
$("#manageDnisDialog").on('hidden.bs.modal', function() {
    //현재 페이지 갱신
    if($('.modal:visible').length == 0){
        location.reload();
    }
});

위와 같이 첫번째 modal <div> 태그가 존재하는 곳에 hidden.bs.modal 이벤트를 등록한다.

그리고 $('.modal:visible').length 를 통해 열려있는 modal 갯수를 확인하고 0 일경우 리로드를 진행한다.

반응형