写一个方法,点击任意除弹窗外的位置关闭当前弹窗

在前端开发中,要实现点击任意除弹窗外的位置关闭当前弹窗的功能,通常可以采用以下步骤:

  1. 为弹窗和遮罩层添加标记:通常,弹窗会有一个特定的类名或ID,以便于识别和操作。同时,你可能需要一个全屏的遮罩层,它位于弹窗之下,用于捕捉点击事件。
  2. 为遮罩层添加点击事件监听器:当用户点击遮罩层时,触发关闭弹窗的动作。
  3. 阻止事件冒泡:确保点击弹窗本身或其内部元素时不会触发遮罩层的点击事件。

以下是一个简单的示例,使用原生JavaScript实现:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Close Popup Example</title>
    <style>
        .popup {
            position: fixed;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            background-color: white;
            border: 1px solid black;
            padding: 20px;
            z-index: 1000;
        }

        .overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0, 0, 0, 0.5);
            z-index: 999;
        }
    </style>
</head>
<body>
    <div class="overlay" id="overlay"></div>
    <div class="popup" id="popup">
        <h2>This is a Popup!</h2>
        <button onclick="closePopup()">Close</button>
    </div>
    <script>
        function closePopup() {
            document.getElementById('popup').style.display = 'none';
            document.getElementById('overlay').style.display = 'none';
        }

        document.getElementById('overlay').addEventListener('click', closePopup);

        // 阻止弹窗内部的点击事件冒泡到遮罩层
        document.getElementById('popup').addEventListener('click', function(event) {
            event.stopPropagation();
        });
    </script>
</body>
</html>

在这个示例中,我们有一个带有类名“popup”的弹窗和一个带有ID“overlay”的遮罩层。当点击遮罩层时,会触发closePopup函数,该函数将弹窗和遮罩层的display属性设置为none,从而隐藏它们。同时,我们为弹窗添加了一个点击事件监听器,当点击弹窗本身时,通过调用event.stopPropagation()来阻止事件冒泡到遮罩层。

posted @   王铁柱6  阅读(125)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
点击右上角即可分享
微信分享提示