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 相关文章推荐
基于DOM+CSS3实现OrgChart组织结构图插件
Mar 02 HTML / CSS
纯CSS3实现鼠标滑过按钮动画第二节
Jul 16 HTML / CSS
HTML5 Plus 实现手机APP拍照或相册选择图片上传功能
Jul 13 HTML / CSS
html5视频播放_动力节点Java学院整理
Jul 13 HTML / CSS
HTML5 File接口在web页面上使用文件下载
Feb 27 HTML / CSS
css 如何让背景图片拉伸填充避免重复显示
Jul 11 HTML / CSS
详解HTML5中的Communication API基本使用方法
Jan 29 HTML / CSS
详解如何用HTML5 Canvas API控制图片的缩放变换
Mar 22 HTML / CSS
h5使用canvas画布实现手势解锁
Jan 04 HTML / CSS
CSS3 制作的书本翻页特效
Apr 13 HTML / CSS
html5调用摄像头实例代码
Jun 28 HTML / CSS
企业开发CSS命名BEM代码规范实践
Feb 12 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实现的漂亮分页方法
2014/04/17 PHP
五款PHP代码重构工具推荐
2014/10/14 PHP
在网页中屏蔽快捷键
2006/09/06 Javascript
提高 DHTML 页面性能
2006/12/25 Javascript
JavaScript版的TwoQueues缓存模型
2014/12/29 Javascript
JavaScript中的数组操作介绍
2014/12/30 Javascript
理解javascript封装
2016/02/23 Javascript
BootStrap实用代码片段之一
2016/03/22 Javascript
Actionscript与javascript交互实例程序(修改)
2016/09/22 Javascript
浅谈React Native Flexbox布局(小结)
2018/01/08 Javascript
基于JavaScript 实现拖放功能
2019/09/12 Javascript
[06:06]2018DOTA2亚洲邀请赛主赛事第四日战况回顾 全明星赛欢乐上演
2018/04/07 DOTA
[45:18]完美世界DOTA2联赛循环赛 PXG vs IO 第二场 11.06
2020/11/09 DOTA
python分析apache访问日志脚本分享
2015/02/26 Python
Python自动化测试Eclipse+Pydev 搭建开发环境
2016/08/15 Python
Python3.4 splinter(模拟填写表单)使用方法
2018/10/13 Python
python数组循环处理方法
2019/08/26 Python
Python开发之基于模板匹配的信用卡数字识别功能
2020/01/13 Python
python3实现将json对象存入Redis以及数据的导入导出
2020/07/16 Python
python如何将图片转换素描画
2020/09/08 Python
jupyter使用自动补全和切换默认浏览器的方法
2020/11/18 Python
使用CSS3来代替JS实现交互
2017/08/10 HTML / CSS
CSS3 mask 遮罩的具体使用方法
2017/11/03 HTML / CSS
html5设计原理(推荐收藏)
2014/05/17 HTML / CSS
新西兰珠宝品牌:Michael Hill
2017/09/16 全球购物
英国天然有机美容护肤品:Neal’s Yard Remedies
2018/05/05 全球购物
微软加拿大官方网站:Microsoft Canada
2019/04/28 全球购物
英国领先的在线鱼贩:The Fish Society
2020/08/12 全球购物
什么是Deployment descriptors;都有什么类型的部署描述符
2015/07/28 面试题
中科创达面试题
2016/12/28 面试题
双语教学实施方案
2014/03/23 职场文书
节能环保标语
2014/06/12 职场文书
房产分割协议书范文
2014/11/21 职场文书
Logback 使用TurboFilter实现日志级别等内容的动态修改操作
2021/08/30 Java/Android
Android开发实现极为简单的QQ登录页面
2022/04/24 Java/Android
使用JS前端技术实现静态图片局部流动效果
2022/08/05 Javascript