【发布时间】:2019-08-08 10:35:17
【问题描述】:
我正在尝试在单击外部时关闭弹出窗口。
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">×</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();
});
});
在该代码块的底部,我有一个隐藏模式的主体上的单击功能,但如果单击modal-content,则触发e.stopPropagation();。
但是,当我单击按钮打开弹出窗口时,由于$("body").click(function(){},它没有打开。
有没有办法可以将$("body").click(function(){} 包装成类似的东西:
if($('.modal').show == true{ ... });
【问题讨论】:
标签: javascript jquery