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 相关文章推荐
让IE可以变相支持CSS3选择器
Jan 21 HTML / CSS
css3教程之倾斜页面
Jan 27 HTML / CSS
纯CSS实现的大小渐变、渐远效果
Apr 15 HTML / CSS
详解HTML5中垂直上下居中的解决方案
Dec 20 HTML / CSS
HTML5+CSS3应用详解
Feb 24 HTML / CSS
使用HTML5中的contentEditable来将多行文本自动增高
Mar 01 HTML / CSS
HTML5之语义标签介绍
Jul 07 HTML / CSS
使用Html5实现异步上传文件,支持跨域,带有上传进度条
Sep 17 HTML / CSS
鼠标滚轮事件和Mac触控板双指事件
Dec 23 HTML / CSS
html5启动原生APP总结
Jul 03 HTML / CSS
CSS3 制作的彩虹按钮样式
Apr 11 HTML / CSS
HTML 里 img 元素的 src 和 srcset 属性的区别详解
May 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
apache+mysql+php+ssl服务器之完全安装攻略
2006/09/05 PHP
Drupal7 form表单二次开发要点与实例
2014/03/02 PHP
PHP中strlen()和mb_strlen()的区别浅析
2014/06/19 PHP
yii操作cookie实例简介
2014/07/09 PHP
php简单实现MVC
2015/02/05 PHP
php 类自动载入的方法
2015/06/03 PHP
PHP获取用户客户端真实IP的解决方案
2016/10/10 PHP
Laravel 简单实现Ajax滚动加载示例
2019/10/22 PHP
Jquery的hover方法让鼠标经过li时背景变色
2013/09/06 Javascript
引用 js在IE与FF之间的区别详细解析
2013/11/20 Javascript
javascript匿名函数实例分析
2014/11/18 Javascript
javascript实现全角半角检测的方法
2015/07/23 Javascript
js实现滚动条滚动到某个位置便自动定位某个tr
2021/01/20 Javascript
javascript判断元素存在和判断元素存在于实时的dom中的方法
2017/01/17 Javascript
Vue组件之全局组件与局部组件的使用详解
2017/10/09 Javascript
详解vue.js之props传递参数
2017/12/12 Javascript
vue-cli配置文件——config篇
2018/01/04 Javascript
详解JavaScript中的数组合并方法和对象合并方法
2018/05/11 Javascript
vuex的module模块用法示例
2018/11/12 Javascript
VUEX采坑之路之获取不到$store的解决方法
2019/11/08 Javascript
基于Vue+Webpack拆分路由文件实现管理
2020/11/16 Javascript
python定时执行指定函数的方法
2015/05/27 Python
Python获取文件所在目录和文件名的方法
2017/01/12 Python
Python使用matplotlib和pandas实现的画图操作【经典示例】
2018/06/13 Python
解决python中使用plot画图,图不显示的问题
2018/07/04 Python
selenium 安装与chromedriver安装的方法步骤
2019/06/12 Python
Tory Burch德国官网:美国时尚生活品牌
2018/01/03 全球购物
Gibson London官网:以地道的英国男装而著称
2019/12/06 全球购物
不用游标的SQL语句有哪些
2012/09/07 面试题
工程现场管理求职自荐信
2013/10/02 职场文书
初中物理教学反思
2014/01/14 职场文书
应届生求职自荐信
2014/07/04 职场文书
2014年为民办实事工作总结
2014/12/20 职场文书
pytorch 预训练模型读取修改相关参数的填坑问题
2021/06/05 Python
利用nginx搭建RTMP视频点播、直播、HLS服务器
2022/05/25 Servers
win10截图快捷键win+shift+s没有反应无法截图怎么解决?
2022/08/14 数码科技