08 一个使用CSS动画和过渡效果的案例

一个使用CSS动画和过渡效果的案例:一个动态加载的图片画廊。这个画廊将展示一系列图片,并使用CSS动画来实现图片的淡入效果和切换动画。

HTML结构 (gallery.html)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>动态图片画廊</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div class="gallery">
        <div class="gallery-item" style="background-image: url(image1.jpg);"></div>
        <div class="gallery-item" style="background-image: url(image2.jpg);"></div>
        <div class="gallery-item" style="background-image: url(image3.jpg);"></div>
        <!-- 更多图片 -->
    </div>
</body>
</html>

CSS样式 (styles.css)

body, html {
    height: 100%;
    margin: 0;
    padding: 0;
}

.gallery {
    display: flex;
    overflow-x: hidden;
    width: 100%;
    height: 100%;
    position: relative;
}

.gallery-item {
    flex: 0 0 100%;
    background-size: cover;
    background-position: center;
    transition: transform 0.5s ease, opacity 0.5s ease;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0; /* 图片初始状态为不可见 */
}

/* 初始状态为第一个图片可见 */
.gallery .gallery-item:first-child {
    opacity: 1;
}

/* 当鼠标悬停在图片上时触发动画 */
.gallery:hover .gallery-item {
    opacity: 1;
    animation: fade 0.5s ease forwards;
}

/* 动画定义 */
@keyframes fade {
    from {
        transform: translateX(100%);
    }
    to {
        transform: translateX(0);
    }
}

/* 鼠标悬停后,除了当前图片外,其他图片向左移动 */
.gallery:hover .gallery-item:not(:first-child) {
    transform: translateX(-100%);
}

/* 鼠标离开画廊后,图片逐渐淡出并移回原位 */
.gallery:not(:hover) .gallery-item {
    opacity: 0;
    transition: opacity 0.5s ease, transform 0.5s ease;
}

代码解释:

  • 页面布局:使用.gallery创建一个全屏的图片容器。
  • 图片容器.gallery-item为每个图片设置样式,包括背景图片、大小和位置。
  • 初始状态:初始时,第一个图片设置为可见。
  • 悬停动画:当鼠标悬停在.gallery上时,所有图片淡入并有一个向左的动画效果。
  • CSS关键帧动画@keyframes fade定义了一个简单的从右向左进入视图的动画。
  • 响应式动画:当鼠标离开画廊时,图片逐渐淡出并移回原位。

这个案例演示了如何使用CSS创建一个动态的图片画廊,其中包括淡入效果和图片切换动画。通过这个案例,你可以了解如何使用CSS动画和过渡来增强网页的视觉效果和用户体验。请注意,实际使用中需要替换image1.jpgimage2.jpg等为实际图片路径。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值