该案例模仿的是华为官网上的,如下图:
实现效果:鼠标移到每一个盒子上时,图片会放大、图片上的文字会上移、背景会有一个加深的效果。
实现思路:
首先,构建布局,给一个.box的div盒子,里面是三个li,每个li里面分别放置了两个div(.pic和.txt),这两个div分别用来放置图片img和文字相关内容。
接着,我们通过flex布局,让每一个li盒子水平排列,且主轴是space-around的排列方式。
然后,我们通过定位,把文本内容放置在下方(left: 0;bottom: -40px;)。给li元素增加after伪类,且宽高与li一致,通过定位把其放置在图片上方,并把透明度设为0。
最后,添加变换。实现鼠标移到每一个盒子上时,图片会放大、图片上的文字会上移、背景会有一个加深的效果。
(注意,通过给叫做.txt的div设置z-index,让其在最上方显示)
实现效果:
代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>综合案例</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
a {
text-decoration: none;
color: black;
}
li {
list-style: none;
}
.box {
display: flex;
justify-content: space-around;
width: 1000px;
height: 219px;
margin: 30px auto;
}
.box ul {
display: flex;
justify-content: space-between;
width: 1000px;
height: 219px;
}
.box li {
position: relative;
overflow: hidden;
width: 310px;
height: 219px;
}
.box .pic img {
width: 310px;
transition: all 0.5s;
}
.box .txt {
position: absolute;
left: 0;
bottom: -40px;
font-size: 16px;
line-height: 25px;
padding: 5px;
color: white;
transition: all 0.5s;
z-index: 999;
}
.box .txt div:nth-child(2) {
font-size: large;
font-weight: bold;
margin-bottom: 30px;
}
.box .txt div:nth-child(3) {
font-size: small;
}
.box li a::after {
position: absolute;
left: 0;
top: 0;
content: '';
width: 310px;
height: 219px;
background-image: linear-gradient(transparent, rgba(0, 0, 0, .6));
transition: all 0.5s;
opacity: 0;
}
/* 逻辑1: 当鼠标移动到.box li元素上时,a::after的透明度变成1*/
.box li:hover a::after {
/* 透明度 */
opacity: 1;
}
/* 逻辑2: 当鼠标移动到.box li元素上时,.pic>img放大1.2倍*/
.box li:hover .pic>img {
transform: scale(1.2);
}
/* 逻辑3: 当鼠标移动到.box li元素上时,.txt上移40px*/
.box li:hover .txt {
transform: translateY(-40px);
}
</style>
</head>
<body>
<div class="box">
<ul>
<li>
<a href="#">
<div class="pic">
<img src="./image/huawei01.jpg" alt="">
</div>
<div class="txt">
<div>成功故事</div>
<div>数字化重构全矿区,绽放一朵行业领先的“红柳之花”</div>
<span>了解更多</span>
<i>></i>
</div>
</a>
</li>
<li>
<a href="#">
<div class="pic">
<img src="./image/huawei01.jpg" alt="">
</div>
<div class="txt">
<div>成功故事</div>
<div>数字化重构全矿区,绽放一朵行业领先的“红柳之花”</div>
<div>
<span>了解更多</span>
<i>></i>
</div>
</div>
</a>
</li>
<li>
<a href="#">
<div class="pic">
<img src="./image/huawei01.jpg" alt="">
</div>
<div class="txt">
<div>成功故事</div>
<div>数字化重构全矿区,绽放一朵行业领先的“红柳之花”</div>
<span>了解更多</span>
<i>></i>
</div>
</a>
</li>
</ul>
</div>
</body>
</html>