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实现字体颜色渐变的实现
Mar 09 HTML / CSS
详解CSS样式中的 !important * _ 符号
Mar 09 HTML / CSS
CSS3美化表单控件全集
Jun 29 HTML / CSS
CSS3 background-image颜色渐变的实现代码
Sep 13 HTML / CSS
css3 自定义字体font-face使用介绍
May 14 HTML / CSS
css3利用transform变形结合事件完成扇形导航
Oct 26 HTML / CSS
HTML5拖拽文件到浏览器并实现文件上传下载功能代码
Jun 06 HTML / CSS
h5调用摄像头的实现方法
Jun 01 HTML / CSS
Canvas引入跨域的图片导致toDataURL()报错的问题的解决
Sep 19 HTML / CSS
HTML实现代码雨源码及效果示例
Feb 25 HTML / CSS
canvas绘制图片drawImage使用方法
Sep 15 HTML / CSS
HTML5 canvas实现的静态循环滚动播放弹幕
Jan 05 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制作静态网站的模板框架(二)
2006/10/09 PHP
让PHP支持页面回退的两种方法[转]
2007/02/14 PHP
PHP+SQL 注入攻击的技术实现以及预防办法
2011/01/27 PHP
PHP 如何利用phpexcel导入数据库
2013/08/24 PHP
限制ckeditor上传图片文件大小的方法
2013/11/15 PHP
PHP中文竖排转换实现方法
2015/10/23 PHP
详解Yii2高级版引入bootstrap.js的一个办法
2017/03/21 PHP
PHP上传图片到数据库并显示的实例代码
2019/12/20 PHP
一份老外写的XMLHttpRequest代码多浏览器支持兼容性
2007/01/11 Javascript
Web跨浏览器进程通信(Web跨域)
2013/04/17 Javascript
window.location.href中url中数据量太大时的解决方法
2013/12/23 Javascript
JavaScript中Null与Undefined的区别解析
2015/06/30 Javascript
jquery过滤特殊字符',防sql注入的实现方法
2016/08/17 Javascript
Vue脚手架的简单使用实例
2018/07/10 Javascript
jQuery 实现倒计时天,时,分,秒功能
2018/07/31 jQuery
[29:16]完美世界DOTA2联赛决赛日 Inki vs LBZS 第三场 11.08
2020/11/10 DOTA
pyqt5的QComboBox 使用模板的具体方法
2018/09/06 Python
安装python依赖包psycopg2来调用postgresql的操作
2021/01/01 Python
CSS3 Notes: -webkit-box-reflect实现倒影的实例
2016/12/08 HTML / CSS
TripAdvisor德国:全球领先的旅游网站
2017/12/07 全球购物
香港草莓网:Strawberrynet香港
2019/05/10 全球购物
Under Armour安德玛荷兰官网:美国高端运动科技品牌
2019/07/10 全球购物
德国滑雪和户外用品网上商店:XSPO
2019/10/30 全球购物
卡拉威高尔夫官方网站:Callaway Golf
2020/09/16 全球购物
Ajax的优点和缺点
2014/11/21 面试题
Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?
2014/07/27 面试题
综合测评自我鉴定
2013/10/08 职场文书
《李广射虎》教学反思
2014/04/27 职场文书
团队激励口号
2014/06/06 职场文书
群众路线教育实践活动自我剖析思想汇报
2014/10/04 职场文书
年终工作总结范文2014
2014/11/27 职场文书
培训后的感想
2015/08/07 职场文书
《作风建设永远在路上》心得体会
2016/01/21 职场文书
工程移交协议书
2016/03/24 职场文书
Node-Red实现MySQL数据库连接的方法
2021/08/07 MySQL
mysql幻读详解实例以及解决办法
2022/06/16 MySQL