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代码实现switch滑动开关按钮效果
Aug 30 HTML / CSS
纯CSS实现预加载动画效果
Sep 06 HTML / CSS
一款纯css3实现的动画加载导航
Oct 08 HTML / CSS
CSS3中颜色线性渐变实战
Jul 18 HTML / CSS
html5中地理位置定位api接口开发应用小结
Jan 04 HTML / CSS
让IE下支持Html5的placeholder属性的插件
Sep 02 HTML / CSS
一些常用的HTML5模式(pattern) 总结
Jul 14 HTML / CSS
HTML5实现音频和视频嵌入的方法
Aug 22 HTML / CSS
HTML5调用手机发短信和打电话功能
Apr 29 HTML / CSS
浅析HTML5页面元素及属性
Jan 20 HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
Apr 29 HTML / CSS
flex布局中使用flex-wrap实现换行的项目实践
Jun 21 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
实用函数5
2007/11/08 PHP
PHP对象克隆clone用法示例
2016/09/28 PHP
利用javascript查看html源文件
2006/11/08 Javascript
extjs 04_grid 单击事件新发现
2012/11/27 Javascript
JS使用replace()方法和正则表达式进行字符串的搜索与替换实例
2014/04/10 Javascript
javascript的tab切换原理与效果实现方法
2015/01/10 Javascript
基于javascript制作微博发布栏效果
2016/04/04 Javascript
基于Turn.js 实现翻书效果实例解析
2016/06/20 Javascript
Json解析的方法小结
2016/06/22 Javascript
浅谈Vue父子组件和非父子组件传值问题
2017/08/22 Javascript
原生JS实现动态加载js文件并在加载成功后执行回调函数的方法
2020/12/30 Javascript
vue+axios+element ui 实现全局loading加载示例
2018/09/11 Javascript
vue中的inject学习教程
2019/04/24 Javascript
使用JavaScript获取Django模板指定键值数据
2020/05/27 Javascript
Vue3不支持Filters过滤器的问题
2020/09/24 Javascript
[48:53]2014 DOTA2华西杯精英邀请赛 5 25 LGD VS VG第一场
2014/05/26 DOTA
Python中的闭包实例详解
2014/08/29 Python
使用Python的内建模块collections的教程
2015/04/28 Python
python+Django+apache的配置方法详解
2016/06/01 Python
centos6.4下python3.6.1安装教程
2017/07/21 Python
python matplotlib坐标轴设置的方法
2017/12/05 Python
使用Python处理Excel表格的简单方法
2018/06/07 Python
Python rstrip()方法实例详解
2018/11/11 Python
详解Python 循环嵌套
2020/07/09 Python
法国二手手袋、手表和奢侈珠宝购物网站:Collector Square
2018/07/05 全球购物
英国知名小木屋定制网站:Tiger Sheds
2020/03/06 全球购物
门诊手术室工作制度
2014/01/30 职场文书
高一化学教学反思
2014/02/05 职场文书
2014年入党积极分子党课学习心得体会模板
2014/04/03 职场文书
跑操口号
2014/06/12 职场文书
学生不讲诚信检讨书
2014/09/29 职场文书
学生上课说话检讨书
2014/10/25 职场文书
检讨书怎么写
2015/01/23 职场文书
python神经网络 使用Keras构建RNN训练
2022/05/04 Python
CSS文本阴影 text-shadow 悬停效果详解
2022/05/25 HTML / CSS
在ubuntu下安装go开发环境的全过程
2022/08/05 Golang