Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

jQuery - Closing modal pop-up by clicking outside of it not working

I'm trying to close a pop-up when clicking outside of it.

HTML

<span class="open"data-modal="modal1">Button</span>

<div class="modal" id="modal1">

    <!--modal content-->
    <div class="modal-content">

        <!--close button-->
        <span class="close">&times;</span>

        <!--content-->

    </div>
</div>

JS

$(document).ready( function() {

    //open pop-up when span is clicked
    $(".open").on("click", function() {
        var modalId = $(this).data("modal");
        var $modal = $("#" + modalId);
        $modal.show();
    });

    //close pop-up when close button is clicked
    $(".close").on("click", function() {
        $(this).closest(".modal").hide();
    });



    $("body").click(function(){
        $(".modal").hide();
    });

    // Prevent events from getting pass .popup
    $(".modal-content").click(function(e){
       e.stopPropagation();
    });

});

At the bottom of that code block, I have a click function on the body that hides the modal, but if modal-content is clicked, then e.stopPropagation(); is fired.

However, when I click the button to open the pop-up, it doesn't open because of $("body").click(function(){}.

Is there a way I can wrap $("body").click(function(){} in something like:

if($('.modal').show == true{ ... });
like image 419
rpivovar Avatar asked Aug 02 '17 22:08

rpivovar


2 Answers

Yes, you could do it like this:

$("body").click(function() {
   if ($(".modal").is(":visible")) {
       $(".modal").hide();
   }
});
like image 56
Maarten van Tjonger Avatar answered Oct 25 '22 03:10

Maarten van Tjonger


All you need to do is the same you already did before, this is to stop the propagation when you click the open button:

//open pop-up when span is clicked
$(".open").on("click", function(e) { //with event now
    e.stopPropagation(); //stopping propagation here
    var modalId = $(this).data("modal");
    var $modal = $("#" + modalId);
    $modal.show();
});

So that it doesn't then call the hide() on the body click handler.

like image 40
Isac Avatar answered Oct 25 '22 01:10

Isac