簡體   English   中英

單擊屏幕關閉燈箱

[英]Close lightbox with click on the screen

我正在做 w3school ( http://www.w3schools.com/howto/howto_js_lightbox.asp ) 的燈箱教程,我想做的是在用戶點擊屏幕時關閉燈箱,但只有當它點擊外面時img 的。

使用我正在使用的這段代碼,用戶點擊的位置無關緊要,它總是關閉燈箱......有沒有辦法解決這個問題。

$( 'body').on('click', function(event) {
     closeModal();
});

嘗試這個:

$('body').on('click', function(event) {
    closeModal();
});

$('#yourLightboxId').on('click', function(event) {
     event.stopPropagation();
});

這將防止點擊事件到達燈箱的父級,其中包括body

保持點擊偵聽器在body上注冊,如下所示:

$('body').on('click', function() {
    closeModal();
});

並且,作為一個簡單的解決方案,將點擊偵聽器附加到燈箱本身以捕獲並吞下它是目標時的任何點擊事件。

$('.lightbox').on('click', function(e) {
    e.stopPropagation();
});

stopPropagation將防止事件冒泡到其他偵聽器,例如document.body 這將確保body的偵聽器不會觸發。

.lightbox替換為您的燈箱容器的唯一選擇器。

$('.yourclassoflightbox').on('click', function(e) {
     e.stopPropagation();
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM