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 3D位移translate效果实例介绍
May 03 HTML / CSS
css3截图_动力节点Java学院整理
Jul 11 HTML / CSS
详解CSS3选择器的使用方法汇总
Nov 24 HTML / CSS
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
May 09 HTML / CSS
CSS3 @media的基本用法总结
Sep 10 HTML / CSS
一篇文章带你学习CSS3图片边框
Nov 04 HTML / CSS
简单整理HTML5的基本特性和语法
Feb 18 HTML / CSS
HTML5中indexedDB 数据库的使用实例
May 11 HTML / CSS
浅谈HTML5 FileReader分布读取文件以及其方法简介
Nov 09 HTML / CSS
html5中canvas图表实现柱状图的示例
Nov 13 HTML / CSS
详解H5 活动页之移动端 REM 布局适配方法
Dec 07 HTML / CSS
遮罩层 + Iframe实现界面自动显示的示例代码
Apr 26 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中对xml读取的相关函数的介绍一
2008/06/05 PHP
PHP实现微信JS-SDK接口选择相册及拍照并上传的方法
2016/12/05 PHP
php函数式编程简单示例
2019/08/08 PHP
onkeydown事件解决按回车键直接提交数据的需求
2013/04/11 Javascript
js操作checkbox遇到的问题解决
2013/06/29 Javascript
使用pjax实现无刷新更改页面url
2015/02/05 Javascript
JavaScript实现简单的数字倒计时
2015/05/15 Javascript
深入学习JavaScript中的Rest参数和参数默认值
2015/07/28 Javascript
详解js数组的完全随机排列算法
2016/12/16 Javascript
关于不同页面之间实现参数传递的几种方式讨论
2017/02/13 Javascript
jQuery中on方法使用注意事项详解
2017/02/15 Javascript
详解nodejs通过响应回写的方式渲染页面资源
2018/04/07 NodeJs
javascript的this关键字详解
2019/05/20 Javascript
适合前端Vue开发童鞋的跨平台Weex的使用详解
2019/10/16 Javascript
python实现ipsec开权限实例
2014/11/11 Python
Python网络爬虫神器PyQuery的基本使用教程
2018/02/03 Python
Python图像处理之图像的读取、显示与保存操作【测试可用】
2019/01/04 Python
Python3.7 dataclass使用指南小结
2019/02/22 Python
Python3.5内置模块之random模块用法实例分析
2019/04/26 Python
使用Python正则表达式操作文本数据的方法
2019/05/14 Python
python绘制评估优化算法性能的测试函数
2019/06/25 Python
Python selenium的基本使用方法分析
2019/12/21 Python
Django ForeignKey与数据库的FOREIGN KEY约束详解
2020/05/20 Python
Python读取Excel一列并计算所有对象出现次数的方法
2020/09/04 Python
台湾前三大B2C购物网站:MOMO购物网
2017/04/27 全球购物
拉拉队口号
2014/06/16 职场文书
道路运输企业安全生产责任书
2014/07/28 职场文书
观看《周恩来的四个昼夜》思想汇报
2014/09/12 职场文书
王兆力在市委党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
2019新员工心得体会
2019/06/25 职场文书
家电创业计划书
2019/08/05 职场文书
2019年感恩励志演讲稿(收藏备用)
2019/09/11 职场文书
写给消防战士们的一封慰问信
2019/10/07 职场文书
Python自然语言处理之切分算法详解
2021/04/25 Python
Nginx如何获取自定义请求header头和URL参数详解
2022/07/23 Servers
LeetCode189轮转数组python示例
2022/08/05 Python