前端web页面实现关灯功能(简洁原生版)

在4399小游戏,网易云音乐mv,B站等浏览器页面上,我们经常能够看到遮罩层:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

遮罩层设计可以用Vue框架实现,但其实Vue实现也是建立在原生实现的基础上,抽取其核心功能如下:

  • 原页面(取消关灯):
    在这里插入图片描述
  • 关灯之后:
    在这里插入图片描述

html架构

<!-- 省略html头部head等信息 -->
<body>
    <div id="main">
        <div id="shadow"></div>
        <button id="btn">关灯</button>
    </div>
</body>

这样基础结构就出来了:
在这里插入图片描述
请格外留意body内的结构:

  • main表示整个container,一般是整个屏幕
  • shadow作为遮罩层,一开始不显示,只有点击按钮才显示
  • button与shadow在同一dom级上(并列)

设计CSS

/* 消除浏览器固有间隙 */
* {
    padding: 0;
    margin: 0;
}
/* 对整个浏览器窗口,同时设置背景图片 */
html {
    height: 100%;
    width: 100%;
}
body {
    height: 100%;
    width: 100%;
    background-image: url("https://www.png8.com/imgs/2020/08/bb5f8741f8be53be.jpeg");
    background-size: cover;
}
/* container占满整个浏览器窗口 */
#main {
    height: 100%;
    width: 100%;
}
/* 设计遮罩层,充斥整个屏幕 */
#shadow {
    position: absolute; 
    visibility: hidden; /* 一开始隐藏起来,不展示 */
    background-color: #000;
    opacity: 0.8;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}
/* button的css */
#btn {
    position: absolute; /* 脱离标准文档流,不受遮罩影响 */
}

添加js逻辑

var btn = document.getElementById('btn');
var sha = document.getElementById('shadow');
btn.onclick = function() {
    sha.style.visibility = 'visible';
}
sha.onclick = function() {
    sha.style.visibility = 'hidden';
}

完整代码

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <style>
            /* 消除浏览器固有间隙 */
            * {
                padding: 0;
                margin: 0;
            }
            /* 对整个浏览器窗口,同时设置背景图片 */
            html {
                height: 100%;
                width: 100%;
            }
            body {
                height: 100%;
                width: 100%;
                background-image: url("https://www.png8.com/imgs/2020/08/bb5f8741f8be53be.jpeg");
                background-size: cover;
            }
            /* container占满整个浏览器窗口 */
            #main {
                height: 100%;
                width: 100%;
            }
            /* 设计遮罩层,充斥整个屏幕 */
            #shadow {
                position: absolute; 
                visibility: hidden; /* 一开始隐藏起来,不展示 */
                background-color: #000;
                opacity: 0.8;
                top: 0;
                bottom: 0;
                left: 0;
                right: 0;
            }
            /* button的css */
            #btn {
                position: absolute; /* 脱离标准文档流,不受遮罩影响 */
            }
        </style>
    </head>
    <body>
        <div id="main">
            <div id="shadow"></div>
            <button id="btn">关灯</button>
        </div>
    </body>
    <script>
        var btn = document.getElementById('btn');
        var sha = document.getElementById('shadow');
        btn.onclick = function() {
            sha.style.visibility = 'visible';
        }
        sha.onclick = function() {
            sha.style.visibility = 'hidden';
        }
    </script>
</html>
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值