使用 HTML、CSS 和 JavaScript 实现滚动触发的小球弹出和切换 Banner 动画

在这篇文章中,我们将通过 HTML、CSS 和 JavaScript 创建一个页面滚动触发的小球弹出动画,并在点击小球后切换不同的 banner 页面。这篇文章适合刚入门的开发者,我们将一步步讲解实现的过程。

前置知识

在开始之前,你需要了解一些基础的 HTML、CSS 和 JavaScript 知识。了解这些内容后,你将能够轻松跟随本教程并实现这个有趣的动画效果。如下:

第一步:创建基本的 HTML 结构

首先,我们需要创建一个基本的 HTML 文件结构。在这个文件中,我们将包含一个滚动区域和一个固定的小球容器。

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Scroll Triggered Animation</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div class="content">
        <div class="scroll-area">
            <p>Scroll down to see the animation...</p>
            <div class="spacer"></div>
        </div>
        <div class="container" id="container">
            <div class="dot" id="dot"></div>
            <div class="expanded" id="expanded">
                <div class="button" data-target="banner1">1</div>
                <div class="button" data-target="banner2">2</div>
                <div class="button" data-target="banner3">3</div>
            </div>
        </div>
    </div>
    <div class="banners">
        <div class="banner" id="banner1">Banner 1</div>
        <div class="banner" id="banner2">Banner 2</div>
        <div class="banner" id="banner3">Banner 3</div>
    </div>
    <script src="script.js"></script>
</body>
</html>
HTML 解释
  1. 我们创建了一个基本的 HTML 结构,包括一个滚动区域 (scroll-area) 和一个固定的小球容器 (container)。
  2. 小球容器包含一个小球 (dot) 和三个按钮 (button),每个按钮都有一个 data-target 属性,用于指向对应的 banner。
  3. 我们还添加了一个 banners 容器,用于包含所有的 banner 页面,每个 banner 都有一个唯一的 ID。
效果如下:

第二步:添加 CSS 样式

接下来,我们需要为我们的 HTML 元素添加样式。我们将使用 CSS 使小球隐藏,并在滚动时显示和展开。此外,我们还会为 banner 页面添加样式。

css 复制代码
/* styles.css */
body {
    margin: 0;
    height: 200vh; /* 确保有足够的高度来滚动 */
    background: #f3f4f6;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.content {
    position: relative;
}

.scroll-area {
    height: 150vh;
}

.spacer {
    height: 100vh; /* 根据需要调整触发动画的位置 */
}

.container {
    display: flex;
    align-items: center;
    gap: 10px;
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    transition: opacity 0.3s;
    opacity: 0; /* 初始状态隐藏 */
}

.dot {
    width: 10px;
    height: 10px;
    background-color: #000;
    border-radius: 50%;
    transition: width 0.3s, height 0.3s, background-color 0.3s;
}

.expanded {
    display: flex;
    gap: 5px;
    overflow: hidden;
    width: 0;
    transition: width 0.3s;
}

.expanded .button {
    width: 10px;
    height: 10px;
    background-color: #000;
    border-radius: 50%;
    cursor: pointer;
}

.banners {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none; /* 初始状态隐藏 */
    justify-content: center;
    align-items: center;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    font-size: 2em;
    transition: opacity 0.3s;
}

.banner {
    display: none; /* 初始状态隐藏 */
}

.banner.active {
    display: block;
}

.banners.active {
    display: flex;
}

CSS 解释

  1. body.content 设置了页面的基本布局和高度,以确保有足够的高度进行滚动。
  2. .container 设置了小球容器的位置和初始状态为隐藏。
  3. .dot.expanded 设置了小球和展开状态的样式,包括过渡效果。
  4. .banners.banner 设置了 banner 页面的样式和显示状态,通过添加 active 类来控制显示和隐藏。
效果如下:

第三步:添加 JavaScript 交互

最后,我们需要添加 JavaScript 来处理滚动事件和点击事件。我们将通过 JavaScript 来检测滚动位置,当页面滚动到一定距离时,显示和展开小球。同时,我们还会添加点击事件来切换 banner 页面。

javascript 复制代码
// script.js
window.addEventListener('scroll', () => {
    const container = document.getElementById('container');
    const dot = document.getElementById('dot');
    const expanded = document.getElementById('expanded');

    if (window.scrollY > 200) { // 根据需要调整触发动画的位置
        container.style.opacity = 1;
        expanded.style.width = '50px'; // 根据需要调整这个值
        dot.style.width = '0px';
        dot.style.height = '0px';
        dot.style.backgroundColor = 'transparent';
    } else {
        container.style.opacity = 0;
        expanded.style.width = '0px';
        dot.style.width = '10px';
        dot.style.height = '10px';
        dot.style.backgroundColor = '#000';
    }
});

document.querySelectorAll('.button').forEach(button => {
    button.addEventListener('click', () => {
        const target = button.getAttribute('data-target');
        document.querySelectorAll('.banner').forEach(banner => {
            banner.classList.remove('active');
        });
        document.getElementById(target).classList.add('active');
        document.querySelector('.banners').classList.add('active');
    });
});

// 点击banner外部区域时关闭banner
document.querySelector('.banners').addEventListener('click', (e) => {
    if (e.target.classList.contains('banners')) {
        document.querySelector('.banners').classList.remove('active');
        document.querySelectorAll('.banner').forEach(banner => {
            banner.classList.remove('active');
        });
    }
});
解释
  1. 我们通过 window.addEventListener('scroll', ...) 监听滚动事件,当页面滚动到一定距离时,显示和展开小球。
  2. 我们为每个按钮添加了点击事件监听,通过 button.addEventListener('click', ...) 切换对应的 banner 页面。
  3. 最后,我们添加了一个点击事件监听,当点击 banner 页面外部区域时,关闭 banner 页面。
最终效果

然后,我们就得到了这样的效果

结论

通过以上步骤,我们实现了一个滚动触发的小球弹出动画,并且可以点击小球切换不同的 banner 页面。这个简单的示例展示了如何结合 HTML、CSS 和 JavaScript 创建交互动画效果。希望这篇文章对刚入门的开发者有所帮助,鼓励大家尝试更多的动画效果,提升自己的前端技能。

相关推荐
cs_dn_Jie6 分钟前
钉钉 H5 微应用 手机端调试
前端·javascript·vue.js·vue·钉钉
开心工作室_kaic40 分钟前
ssm068海鲜自助餐厅系统+vue(论文+源码)_kaic
前端·javascript·vue.js
有梦想的刺儿1 小时前
webWorker基本用法
前端·javascript·vue.js
清灵xmf2 小时前
TypeScript 类型进阶指南
javascript·typescript·泛型·t·infer
小白学大数据2 小时前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
qq_390161772 小时前
防抖函数--应用场景及示例
前端·javascript
334554323 小时前
element动态表头合并表格
开发语言·javascript·ecmascript
John.liu_Test3 小时前
js下载excel示例demo
前端·javascript·excel
PleaSure乐事3 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶3 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json