Html5页面点击遮罩层背景关闭遮罩层


Posted in HTML / CSS onNovember 30, 2020

今天团队同事接到一个需求,需求是这样的,点击页面按钮弹出红包弹窗,显示黑色遮罩层,点击遮罩层背景和弹窗关闭按钮要关闭弹窗,于是我就做了一个Demo出来,方便以后下次自己再遇到这种需求,上代码。

html代码

页面上只有一个展示的按钮,一个ID为bg的div作为灰色背景遮罩层使用,ID为popup的div作为红包弹窗,ID为close的div作为关闭按钮。

<body>
    <div class="btn" id="btn">展示</div>
    <div class="bg" id="bg">
        <div class="popup" id="popup">
            <div class="close" id="close">X</div>
        </div>
    </div>
</body>

CSS代码

css代码里面没什么技术难点,唯一要注意的是要给灰色背景的遮罩层一个绝对定位,top和lefe都为0就好了

body {
        position: relative;
    }
    .btn {
        width: 100px;
        height: 40px;
        line-height: 40px;
        text-align: center;
        margin:20px auto 0;
        border: 1px solid #333;
        border-radius: 10px;
    }
    .bg {
        width: 100%;
        height: 100%;
        position: fixed;
        top: 0;
        left: 0;
        background-color: rgba(0, 0, 0, .6);
        display: none;
    }
    .popup {
        width: 260px;
        height: 320px;
        background: red;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        border-radius: 15px;
     }
    .popup .close {
        width: 30px;
        height: 30px;
        line-height: 30px;
        text-align: center;
        position: absolute;
        top: -40px;
        right: 0px;
        border: 1px solid #999;
        border-radius: 50%;
        color: #999;
    }

JS代码

var btn = document.getElementById('btn');
    var bg = document.getElementById('bg');
    var popup = document.getElementById('popup');
    var closeBtn = document.getElementById('close');
    // 点击展示按钮显示弹窗
    btn.addEventListener('click', ()=> {
        bg.style.display = 'block';
    });
    // 点击阴影遮罩层关闭弹窗
    bg.addEventListener('click', (e)=> {
        bg.style.display = 'none'
    });
    // 阻止冒泡事件,点击弹窗不会执行父元素的点击事件
    popup.addEventListener('click', (e)=> {
        e.stopPropagation();
    });
    // 点击关闭符号关闭弹窗
    closeBtn.addEventListener('click', (e)=> {
        e.stopPropagation();
        bg.style.display = 'none'
    })

到此这篇关于Html5页面点击遮罩层背景关闭遮罩层的文章就介绍到这了,更多相关Html5关闭遮罩层内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
利用CSS3的transform做的动态时钟效果
Sep 21 HTML / CSS
CSS3基础(RGBa、text-shadow、box-shadow、border-radius)
Nov 13 HTML / CSS
使用CSS3创建动态菜单效果
Jul 10 HTML / CSS
CSS3制作炫酷的自定义发光文字
Mar 28 HTML / CSS
用CSS3打造HTML5的Logo(实现代码)
Jun 16 HTML / CSS
HTML5新增的Css选择器、伪类介绍
Aug 07 HTML / CSS
html5 利用重力感应实现摇一摇换颜色可用来做抽奖等等
May 07 HTML / CSS
h5调用摄像头的实现方法
Jun 01 HTML / CSS
详解canvas多边形(蜘蛛图)的画法示例
Jan 29 HTML / CSS
canvas简单连线动画的实现代码
Feb 04 HTML / CSS
完美实现CSS垂直居中的11种方法
Mar 27 HTML / CSS
浅谈为什么我的 z-index 又不生效了
Jul 15 HTML / CSS
使用HTML5加载音频和视频的实现代码
Nov 30 #HTML / CSS
Canvas实现放大镜效果完整案例分析(附代码)
Nov 26 #HTML / CSS
HTML5在手机端实现视频全屏展示方法
Nov 23 #HTML / CSS
关于HTML5+ API plusready的兼容问题
Nov 20 #HTML / CSS
Html5原生拖拽相关事件简介以及基础实现
Nov 19 #HTML / CSS
Canvas获取视频第一帧缩略图的实现
Nov 11 #HTML / CSS
使用layui框架实现点击左侧导航切换右侧内容且右侧选项卡跟随变化的效果
Nov 10 #HTML / CSS
You might like
php 远程图片保存到本地的函数类
2008/12/08 PHP
PHP mcrypt可逆加密算法分析
2011/07/19 PHP
phpcms的分类名称和类别名称的调用
2017/01/05 PHP
safari下载文件自动加了html后缀问题
2018/11/09 PHP
php解析非标准json、非规范json的方式实例
2020/12/10 PHP
Jquery 滑入滑出效果实现代码
2010/03/27 Javascript
在jQuery 1.5中使用deferred对象的代码(翻译)
2011/03/10 Javascript
javascript判断两个IP地址是否在同一个网段的实现思路
2013/12/13 Javascript
VS2008中使用JavaScript调用WebServices
2014/12/18 Javascript
详解addEventListener的三个参数之useCapture
2015/03/16 Javascript
JavaScript将数组转换成CSV格式的方法
2015/03/19 Javascript
jquery实现移动端点击图片查看大图特效
2020/09/11 Javascript
Treegrid的动态加载实例代码
2016/04/29 Javascript
jquery获取img的src值的简单实例
2016/05/17 Javascript
window.open不被拦截的简单实现代码(推荐)
2016/08/04 Javascript
基于JavaScript实现树形下拉框
2016/08/10 Javascript
javascript 使用正则test( )第一次是 true,第二次是false
2017/02/22 Javascript
vue2.x 父组件监听子组件事件并传回信息的方法
2017/07/17 Javascript
Nodejs技巧之Exceljs表格操作用法示例
2019/11/06 NodeJs
[48:46]完美世界DOTA2联赛PWL S2 SZ vs FTD.C 第二场 11.19
2020/11/19 DOTA
Python中对象的引用与复制代码示例
2017/12/04 Python
Python运维开发之psutil库的使用详解
2018/10/18 Python
Python判断telnet通不通的实例
2019/01/26 Python
seek引发的python文件读写的问题及解决
2019/07/26 Python
Windows系统Python直接调用C++ DLL的方法
2019/08/01 Python
PyCharm 2020 激活到 2100 年的教程
2020/03/25 Python
Python 图片处理库exifread详解
2021/02/25 Python
实体的生命周期
2013/08/31 面试题
swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上
2013/07/06 面试题
创意活动策划书
2014/01/15 职场文书
《七颗钻石》教学反思
2014/02/28 职场文书
个人担保书格式范文
2014/05/12 职场文书
作文批改评语
2014/12/25 职场文书
2015年初三班主任工作总结
2015/05/21 职场文书
春晚观后感
2015/06/11 职场文书
结婚典礼致辞
2015/07/28 职场文书