css盒子遮罩层显示与隐藏

这篇博客详细介绍了如何使用HTML和CSS逐步创建一个带有遮罩层的图片展示效果。首先制作一个盒子并设置尺寸,然后在盒子内放入图片使其全屏显示,接着添加遮罩层并设置为绝对定位,再通过相对定位使遮罩层覆盖整个盒子。最后,通过CSS的:hover伪类实现鼠标悬停时遮罩层显示的效果。

实现效果要如图显示:
在这里插入图片描述
在这里插入图片描述
素材:两张图片
步骤一:制作一个盒子,记住它的尺寸和大小
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>盒子遮罩层的显示与隐藏</title>
    <style>
        .box {
            width: 444px;
            height: 320px;
            margin: 100px auto;
            background-color: salmon;
        }
    </style>
</head>
<body>
    <!-- 步骤一:制作一个盒子出来 -->
    <div class="box">

    </div>
</body>
</html>

运行结果如下:
在这里插入图片描述
第二步:盒子里面放置一张图片,尺寸跟盒子100%对齐就可以了。
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>盒子遮罩层的显示与隐藏</title>
    <style>
        .box {
            width: 444px;
            height: 320px;
            margin: 100px auto;
            background-color: salmon;
        }
        .box img {
            width: 100%;
            height: 100%;
        }
    </style>
</head>
<body>
    <!-- 步骤一:制作一个盒子出来 -->
    <div class="box">
        <img src="images/img.jpg" alt="">
    </div>
</body>
</html>

运行结果如下:
在这里插入图片描述
第三步:设置遮罩层盒子。
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>盒子遮罩层的显示与隐藏</title>
    <style>
        .box {
            width: 444px;
            height: 320px;
            margin: 100px auto;
            background-color: salmon;
        }
        .box img {
            width: 100%;
            height: 100%;
        }
        .box .mask {
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3) url(images/arr.png) no-repeat center;

        }
    </style>
</head>
<body>
    <!-- 步骤一:制作一个盒子出来 --> 
    <div class="box">
        <!-- /* 步骤二:盒子里面放置图片 */ -->
        <img src="images/img.jpg" alt="">
        <!-- /* 步骤三:盒子里面放置遮罩层 */ -->
        <div class="mask"></div>
    </div>
</body>

</html>

运行结果如下:
在这里插入图片描述
步骤四:目前是标准流盒子,所以上下排布,我们把遮罩层设置为绝对定位,就好了
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>盒子遮罩层的显示与隐藏</title>
    <style>
        .box {
            width: 444px;
            height: 320px;
            margin: 100px auto;
            background-color: salmon;
        }
        .box img {
            width: 100%;
            height: 100%;
        }
        .box .mask {
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3) url(images/arr.png) no-repeat center;
            position: absolute;
            top: 0;
            left: 0;
        }
    </style>
</head>
<body>
    <!-- 步骤一:制作一个盒子出来 --> 
    <div class="box">
        <!-- /* 步骤二:盒子里面放置图片 */ -->
        <img src="images/img.jpg" alt="">
        <!-- /* 步骤三:盒子里面放置遮罩层 */ -->
        <div class="mask"></div>
    </div>
</body>

</html>

运行结果如下:
在这里插入图片描述
步骤五:因为我们要在父盒子里面全屏显示的话,要设置子绝父相呀。给父亲加上相对定位试试。
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>盒子遮罩层的显示与隐藏</title>
    <style>
        .box {
            width: 444px;
            height: 320px;
            margin: 100px auto;
            background-color: salmon;
            position: relative;
        }
        .box img {
            width: 100%;
            height: 100%;
        }
        .box .mask {
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3) url(images/arr.png) no-repeat center;
            position: absolute;
            top: 0;
            left: 0;
        }
    </style>
</head>
<body>
    <!-- 步骤一:制作一个盒子出来 --> 
    <div class="box">
        <!-- /* 步骤二:盒子里面放置图片 */ -->
        <img src="images/img.jpg" alt="">
        <!-- /* 步骤三:盒子里面放置遮罩层 */ -->
        <div class="mask"></div>
    </div>
</body>

</html>

运行结果如下:
在这里插入图片描述
步骤五:设置成鼠标滑过盒子的时候遮罩层出现。
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>盒子遮罩层的显示与隐藏</title>
    <style>
        .box {
            width: 444px;
            height: 320px;
            margin: 100px auto;
            background-color: salmon;
            position: relative;
        }
        .box img {
            width: 100%;
            height: 100%;
        }
        .box .mask {
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3) url(images/arr.png) no-repeat center;
            position: absolute;
            top: 0;
            left: 0;
            /* 先让遮罩层隐藏 */
            display: none;
        }
        /* 鼠标滑过盒子的时候遮罩层出现 */
        .box:hover .mask {
            display: block;
        }
    </style>
</head>
<body>
    <!-- 步骤一:制作一个盒子出来 --> 
    <div class="box">
        <!-- /* 步骤二:盒子里面放置图片 */ -->
        <img src="images/img.jpg" alt="">
        <!-- /* 步骤三:盒子里面放置遮罩层 */ -->
        <div class="mask"></div>
    </div>
</body>

</html>

运行结果如下:
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值