用hover实现图片遮罩层的出现和消失

用hover实现图片遮罩层的出现和消失

html部分

我在这里建立了三个盒子,可以看出div1里面包含div2和div3,div2和div3都是遮罩层。
遮罩层必须放在大盒子的里面

<div class="div1">
    <div class="div2">
    </div>
    <div class="div3">
    </div>
</div>

css部分

我们先做div1和div2的样式部分,除了基本的宽高、背景颜色的设置,div1的位置必须是相对定位,div2也就是遮罩层必须是绝对定位。当鼠标移入的时候,遮罩层的透明度由0.6变成0,为了让切换看上去平滑一点,那么我们用了transition

 .div1{
        position: relative;       *相对定位*
        height:200px;
        width:200px;
        background-color: pink;
    }
    .div2{
        position: absolute;      *绝对定位*
        height:200px;
        width:200px;
        background-color: black;
        opacity: .6;      *透明度*
    }
    .div1:hover .div2{
        opacity: 0;        *透明度*
        transition: all .6s ease;
    }
    

css部分

接着我们来做div1和div3的样式部分,除了基本的宽高、背景颜色的设置,div1的位置必须是相对定位,div3也就是遮罩层必须是绝对定位。鼠标未移入div1,div3在盒子下面,并且隐藏,当鼠标移入的时候,div3就会进入div1,在这里,我用底部距离实现盒子的出现和隐藏。同样用transition实现动画的平滑性。

.div1{
        position: relative;    *相对定位*
        height:200px;
        width:200px;
        background-color: pink;
        overflow: hidden; *让多出盒子外的东西实现隐藏*
    }
.div3{
        position: absolute; *绝对定位*
        height:50px;
        width:200px;
        background-color: firebrick;
        bottom:-50px;
        opacity: .6;
    }
      .div1:hover .div3{
        bottom:0;
        transition: all .6s ease;
  }

完整代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
    *{
       padding:0;
        margin:0;
    }
    .div1{
        position: relative;
        height:200px;
        width:200px;
        background-color: pink;
        overflow: hidden;
    }
    .div2{
        position: absolute;
        height:200px;
        width:200px;
        background-color: black;
        opacity: .6;
    }
    .div3{
        position: absolute;
        height:50px;
        width:200px;
        background-color: firebrick;
        bottom:-50px;
          opacity: .6;
    }
    .div1:hover .div2{
        opacity: 0;
        transition: all .6s ease;
    }
    .div1:hover .div3{
        bottom:0;
        transition: all .6s ease;
     }
</style>
<body>
<div class="div1">
    <div class="div2">
    </div>
    <div class="div3">
    </div>
</div>
</body>
</html>

至此,我们实现了用hover实现图片遮罩层的出现和消失。

可以使用CSS的伪类选择器`:hover`以及`::before`或`::after`伪元素来实现背景图片hover加蒙层的效果。 具体实现步骤如下: 1. 给需要添加背景图片的元素设置一个相对定位的父级元素,并设置背景图片。 2. 给该父级元素设置一个宽高和`overflow:hidden`,以隐藏超出父级元素的内容。 3. 使用`::before`或`::after`伪元素来创建一个遮罩层,并设置其宽高和背景颜色,透明度等属性。 4. 给遮罩层添加`transition`属性,以实现渐变过渡效果。 5. 使用`opacity`属性来控制遮罩层的透明度,当鼠标移至图片上时,通过`:hover`伪类选择器来控制遮罩层的透明度。 6. 在遮罩层中添加需要显示的文字或其他内容。 示例代码如下: HTML: ``` <div class="box"> <div class="bg"></div> <div class="mask"> <h2>这是遮罩层</h2> <p>这是遮罩层中的文字内容</p> </div> </div> ``` CSS: ``` .box { position: relative; width: 300px; height: 200px; overflow: hidden; } .bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(图片地址) no-repeat center center; background-size: cover; } .mask { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 0.3s ease; background-color: rgba(0, 0, 0, 0.5); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: #fff; } .box:hover .mask { opacity: 1; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值