H5 图片展示区宽为720px,展示区水平居中 每行显示三个张图,有多张自动换行,一行不满三张,左边对齐 图片底有个透明度为.5的蒙板,写图片描述的文字,高度为2rem 实现特效,当光标移入时,图片放大1.1倍,离开还原
时间: 2024-03-17 14:45:56 浏览: 87
这个问题涉及到前端页面的布局和交互特效,可以使用HTML、CSS和JavaScript来实现。以下是一个简单的实现方案:
HTML代码:
```html
<div class="image-list">
<div class="image-item">
<img src="image1.jpg">
<div class="description">图片描述1</div>
</div>
<div class="image-item">
<img src="image2.jpg">
<div class="description">图片描述2</div>
</div>
<div class="image-item">
<img src="image3.jpg">
<div class="description">图片描述3</div>
</div>
<!-- 其他图片项 -->
</div>
```
CSS代码:
```css
.image-list {
width: 720px;
margin: 0 auto;
display: flex;
flex-wrap: wrap;
}
.image-item {
width: calc(33.33% - 10px);
margin-right: 10px;
margin-bottom: 10px;
position: relative;
}
.image-item img {
display: block;
width: 100%;
height: auto;
transition: transform 0.2s ease-out;
}
.image-item .description {
position: absolute;
bottom: 0;
left: 0;
right: 0;
background-color: rgba(0, 0, 0, 0.5);
color: #fff;
font-size: 14px;
height: 2rem;
padding: 0.5rem;
box-sizing: border-box;
}
.image-item:hover img {
transform: scale(1.1);
}
```
解释一下CSS的实现:
1. `image-list`是一个div容器,设置宽度为720px,并且水平居中显示。
2. `image-item`是每个图片项的容器,设置宽度为33.33%,也就是一行显示三个,同时设置右边距和下边距为10px,实现图片间的间距。注意,这里使用`calc()`函数计算宽度,去掉右边距的10px。
3. `image-item img`是图片元素,设置宽度为100%自适应容器宽度,高度自适应,同时设置一个过渡效果,当鼠标移入时,图片元素的`transform`属性会从默认值(1)变为1.1,实现放大特效。
4. `image-item .description`是图片描述文字的容器,设置绝对定位在图片底部,并且设置一个透明度为0.5的黑色背景,同时设置文字颜色为白色,字号为14px,高度为2rem,实现文字的布局和样式。
JavaScript部分可以不用编写,这个特效可以直接使用CSS实现。
阅读全文