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实现信纸/同学录效果的示例代码
Dec 11 HTML / CSS
详解CSS3中nth-child与nth-of-type的区别
Jan 05 HTML / CSS
HTML5 Canvas API中drawImage()方法的使用实例
Mar 25 HTML / CSS
HTML5之多线程(Web Worker)
Jan 02 HTML / CSS
HTML5实现锚点时请使用id取代name
Sep 06 HTML / CSS
HTML5制作酷炫音频播放器插件图文教程
Dec 30 HTML / CSS
HTML5 video标签(播放器)学习笔记(二):播放控制
Apr 24 HTML / CSS
推荐WEB开发者最佳HTML5和CSS3代码生成器
Nov 24 HTML / CSS
Web前端页面跳转并取到值
Apr 24 HTML / CSS
详解html5页面 rem 布局适配方法
Jan 12 HTML / CSS
浅谈css实现背景颜色半透明的两种方法
Dec 06 HTML / CSS
VW、VH适配移动端的解决方案与常见问题
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
php 使用curl模拟登录人人(校内)网的简单实例
2016/06/06 PHP
实现php删除链表中重复的结点
2018/09/27 PHP
页面版文本框智能提示JS代码
2009/11/20 Javascript
jQuery学习笔记(3)--用jquery(插件)实现多选项卡功能
2013/04/08 Javascript
jquery 删除cookie失效的解决方法
2013/11/12 Javascript
jquery链式操作的正确使用方法
2014/01/06 Javascript
js showModalDialog 弹出对话框的简单实例(子窗体)
2014/01/07 Javascript
node.js使用npm 安装插件时提示install Error: ENOENT报错的解决方法
2014/11/20 Javascript
浅谈jQuery事件绑定原理
2015/01/02 Javascript
nodejs爬虫抓取数据之编码问题
2015/07/03 NodeJs
JS 对象(Object)和字符串(String)互转方法
2016/05/20 Javascript
js动态获取子复选项并设计全选及提交的实现方法
2016/06/24 Javascript
JavaScript数组操作函数汇总
2016/08/05 Javascript
jQuery实现Select左右复制移动内容
2016/08/05 Javascript
JSONP跨域请求
2017/03/02 Javascript
Webpack中css-loader和less-loader的使用教程
2017/04/27 Javascript
jQuery轻量级表单模型验证插件
2018/10/15 jQuery
原生JavaScript实现日历功能代码实例(无引用Jq)
2019/09/23 Javascript
[55:35]DOTA2-DPC中国联赛 正赛 CDEC vs Dragon BO3 第二场 1月22日
2021/03/11 DOTA
Python中下划线的使用方法
2015/03/27 Python
Python使用面向对象方式创建线程实现12306售票系统
2015/12/24 Python
分析Python中解析构建数据知识
2018/01/20 Python
详解Python 装饰器执行顺序迷思
2018/08/08 Python
学python安装的软件总结
2019/10/12 Python
html5超简单的localStorage实现记住密码的功能实现
2017/09/07 HTML / CSS
中国跨境电商:Tomtop
2017/03/16 全球购物
考博专家推荐信模板
2013/12/02 职场文书
土木工程专业个人求职信
2013/12/30 职场文书
党支部公开承诺践诺书
2014/03/28 职场文书
《毛主席在花山》教学反思
2014/04/20 职场文书
文明礼貌演讲稿
2014/05/12 职场文书
管理标语大全
2014/06/24 职场文书
工厂门卫的岗位职责
2014/07/27 职场文书
2014标准社保办理委托书
2014/10/06 职场文书
2019关于垃圾分类处理的调查报告
2019/12/26 职场文书
《乙女游戏世界对路人角色很不友好》OP主题曲无字幕动画MV公开
2022/04/05 日漫