首页 话题 小组 问答 好文 用户 我的社区 域名交易 唠叨

[分享]css像卡片左进右出怎么实现

发布于 2024-11-11 15:53:06
0
11

CSS卡片左进右出实现

/*HTML结构*/
<div class="wrapper">
  <div class="card left">
    <img src="image1.jpg">
  </div>
  <div class="card center">
    <img src="image2.jpg">
  </div>
  <div class="card right">
    <img src="image3.jpg">
  </div>
</div>

/*CSS样式*/
.wrapper {
  width: 600px;
  height: 400px;
  margin: 0 auto;
  overflow: hidden;
}

.card {
  position: absolute;
  top: 30px;
  width: 300px;
  height: 340px;
  border-radius: 10px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
  transition: all ease-in-out 0.5s;
}

.left {
  left: 0;
  transform: translateX(-50%);
}

.center {
  left: 50%;
  transform: translateX(-50%) scale(1.05);
  z-index: 1;
}

.right {
  right: 0;
  transform: translateX(50%);
}

.wrapper:hover .left {
  transform: translateX(-100%) scale(0.9);
}

.wrapper:hover .center {
  transform: translateX(-50%) scale(1);
}

.wrapper:hover .right {
  transform: translateX(100%) scale(0.9);
} 

说明:

在HTML结构中,我们使用三个div分别表示三张图片,然后设置三个类名分别为left、center、right,然后在CSS样式中对这三个元素进行设置。

首先,我们设置.wrapper的宽高为600px和400px,然后设置overflow为hidden,表示我们只展示wrapper内的css卡片内容,如果超出wrapper的范围,就不显示。

然后,我们对.card进行设置,我们把左侧卡片设置为绝对定位,然后左侧和右侧的卡片设置定位left:0和right:0分别靠左和靠右,然后是中间的卡片设置left:50%,表示它出现在wrapper中间。我们还需要设置卡片的一些其他样式,如卡片的大小、边框、圆角、盒子阴影等。

接着,我们通过CSS3 transform属性来控制每个卡片的位置和大小。我们初始时设置左侧卡片left:-50%,中间卡片left:50%和右侧卡片right:-50%,这样就可以让左侧卡片向左偏移50%的wrapper宽度,即隐藏。中间卡片在左侧的基础上再向左偏移50%的宽度,并且设置scale(1.05)来放大一些。右侧卡片向右偏移50%的宽度,即隐藏。

最后,我们为wrapper添加鼠标悬停事件(:hover),然后分别对三个卡片设置不同的transform属性值。当鼠标悬停在wrapper上时,左侧卡片translateX(-100%)向左移动100%的宽度,即完全隐藏,中间卡片只需要还原到原始比例即可,而右侧卡片translateX(100%)向右移动100%的宽度,即完全隐藏。

这样,我们就实现了CSS卡片左进右出效果。

评论
一个月内的热帖推荐
91云脑
Lv.1普通用户

62849

帖子

14

小组

291

积分

赞助商广告
站长交流