模板特点

  • 响应式设计: 适配桌面、平板和手机等各种设备。
  • 现代美观: 使用了流行的设计风格,包括卡片布局、渐变色和流畅的动画。
  • 功能完整: 包含了轮播图、课程筛选、教练展示等常见功能模块。
  • 代码清晰: 结构化的 HTML5 语义化标签,易于理解和修改。
  • 交互丰富: 使用原生 JavaScript 实现了动态效果,无需依赖外部框架。

文件结构

为了方便管理,建议您创建以下文件结构:

html5运动健身模板
(图片来源网络,侵删)
fitness-website/
├── index.html          # 首页
├── css/
│   └── style.css       # 全局样式
├── js/
│   └── script.js       # 交互脚本
├── images/
│   ├── hero-bg.jpg     # 首页背景图
│   ├── coach-1.jpg     # 教练图片
│   ├── coach-2.jpg
│   ├── coach-3.jpg
│   ├── class-1.jpg     # 课程图片
│   ├── class-2.jpg
│   └── class-3.jpg
└── fonts/
    └── (可选,放置自定义字体)

CSS 样式 (css/style.css)

我们创建一个统一的样式文件。

/* --- 全局样式重置与变量 --- */
:root {
    --primary-color: #FF6B6B; /* 主色调,活力橙红 */
    --secondary-color: #4ECDC4; /* 辅助色,清新青绿 */
    --dark-color: #2C3E50; /* 深色,用于文字和背景 */
    --light-color: #F7F7F7; /* 浅色,用于背景 */
    --text-color: #333;
    --shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
    color: var(--text-color);
    background-color: #fff;
}
a {
    text-decoration: none;
    color: var(--primary-color);
}
ul {
    list-style: none;
}
.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 2rem;
}
.section-title {
    text-align: center;
    font-size: 2.5rem;
    margin-bottom: 1rem;
    color: var(--dark-color);
}
.section-subtitle {
    text-align: center;
    font-size: 1.1rem;
    color: #777;
    margin-bottom: 3rem;
}
.btn {
    display: inline-block;
    padding: 0.8rem 2rem;
    background: var(--primary-color);
    color: #fff;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    font-size: 1rem;
    transition: background 0.3s ease, transform 0.3s ease;
}
.btn:hover {
    background: #ff5252;
    transform: translateY(-3px);
}
/* --- 导航栏 --- */
.navbar {
    background: #fff;
    box-shadow: var(--shadow);
    position: sticky;
    top: 0;
    z-index: 1000;
}
.navbar .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
}
.navbar .logo {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--primary-color);
}
.navbar .nav-links {
    display: flex;
    gap: 2rem;
}
.navbar .nav-links a {
    color: var(--dark-color);
    font-weight: 500;
    transition: color 0.3s ease;
}
.navbar .nav-links a:hover {
    color: var(--primary-color);
}
.navbar .menu-toggle {
    display: none;
    flex-direction: column;
    cursor: pointer;
}
.navbar .menu-toggle span {
    width: 25px;
    height: 3px;
    background: var(--dark-color);
    margin: 3px 0;
    transition: 0.3s;
}
/* --- 首页英雄区域 --- */
.hero {
    height: 100vh;
    background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('../images/hero-bg.jpg') no-repeat center center/cover;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #fff;
}
.hero-content h1 {
    font-size: 3.5rem;
    margin-bottom: 1rem;
}
.hero-content p {
    font-size: 1.2rem;
    margin-bottom: 2rem;
}
/* --- 特色区域 --- */
.features {
    padding: 4rem 0;
    background: var(--light-color);
}
.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    text-align: center;
}
.feature-card {
    background: #fff;
    padding: 2rem;
    border-radius: 10px;
    box-shadow: var(--shadow);
    transition: transform 0.3s ease;
}
.feature-card:hover {
    transform: translateY(-10px);
}
.feature-card i {
    font-size: 3rem;
    color: var(--secondary-color);
    margin-bottom: 1rem;
}
/* --- 课程区域 --- */
.classes {
    padding: 4rem 0;
}
.filter-buttons {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}
.filter-btn {
    padding: 0.5rem 1.5rem;
    border: 2px solid var(--primary-color);
    background: transparent;
    color: var(--primary-color);
    border-radius: 25px;
    cursor: pointer;
    transition: all 0.3s ease;
}
.filter-btn.active,
.filter-btn:hover {
    background: var(--primary-color);
    color: #fff;
}
.classes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
}
.class-card {
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: transform 0.3s ease;
}
.class-card:hover {
    transform: translateY(-5px);
}
.class-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}
.class-card-content {
    padding: 1.5rem;
}
.class-card-content h3 {
    margin-bottom: 0.5rem;
    color: var(--dark-color);
}
.class-card-content p {
    color: #777;
    margin-bottom: 1rem;
}
.class-meta {
    display: flex;
    justify-content: space-between;
    font-size: 0.9rem;
    color: #888;
}
/* --- 教练区域 --- */
.trainers {
    padding: 4rem 0;
    background: var(--light-color);
}
.trainers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
}
.trainer-card {
    background: #fff;
    text-align: center;
    padding: 2rem 1rem;
    border-radius: 10px;
    box-shadow: var(--shadow);
}
.trainer-card img {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 1rem;
}
.trainer-card h3 {
    margin-bottom: 0.5rem;
}
.trainer-card p {
    color: #777;
    margin-bottom: 1rem;
}
.social-links {
    display: flex;
    justify-content: center;
    gap: 1rem;
}
.social-links a {
    color: var(--dark-color);
    font-size: 1.2rem;
}
/* --- 页脚 --- */
.footer {
    background: var(--dark-color);
    color: #fff;
    text-align: center;
    padding: 2rem 0;
}
.footer p {
    margin-bottom: 0.5rem;
}
/* --- 响应式设计 --- */
@media (max-width: 768px) {
    .navbar .nav-links {
        position: fixed;
        left: -100%;
        top: 70px;
        flex-direction: column;
        background-color: #fff;
        width: 100%;
        text-align: center;
        transition: 0.3s;
        box-shadow: var(--shadow);
        padding: 2rem 0;
    }
    .navbar .nav-links.active {
        left: 0;
    }
    .navbar .menu-toggle {
        display: flex;
    }
    .hero-content h1 {
        font-size: 2.5rem;
    }
    .hero-content p {
        font-size: 1rem;
    }
    .section-title {
        font-size: 2rem;
    }
}

JavaScript 交互 (js/script.js)

这个脚本负责移动端菜单的切换和课程筛选功能。

// 等待 DOM 加载完成
document.addEventListener('DOMContentLoaded', () => {
    // --- 移动端菜单切换 ---
    const menuToggle = document.querySelector('.menu-toggle');
    const navLinks = document.querySelector('.nav-links');
    menuToggle.addEventListener('click', () => {
        navLinks.classList.toggle('active');
    });
    // 点击菜单项后关闭菜单
    document.querySelectorAll('.nav-links a').forEach(link => {
        link.addEventListener('click', () => {
            navLinks.classList.remove('active');
        });
    });
    // --- 课程筛选功能 ---
    const filterButtons = document.querySelectorAll('.filter-btn');
    const classCards = document.querySelectorAll('.class-card');
    filterButtons.forEach(button => {
        button.addEventListener('click', () => {
            // 移除所有按钮的 'active' 类
            filterButtons.forEach(btn => btn.classList.remove('active'));
            // 给当前点击的按钮添加 'active' 类
            button.classList.add('active');
            const filterValue = button.getAttribute('data-filter');
            classCards.forEach(card => {
                if (filterValue === 'all' || card.getAttribute('data-category') === filterValue) {
                    card.style.display = 'block';
                } else {
                    card.style.display = 'none';
                }
            });
        });
    });
});

HTML 页面 (index.html)

这是首页,它将所有部分整合在一起。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">FitLife 健身中心 - 开启你的健康生活</title>
    <link rel="stylesheet" href="css/style.css">
    <!-- 引入 Font Awesome 图标库 -->
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
</head>
<body>
    <!-- 导航栏 -->
    <nav class="navbar">
        <div class="container">
            <a href="#" class="logo">FitLife</a>
            <ul class="nav-links">
                <li><a href="#home">首页</a></li>
                <li><a href="#classes">课程</a></li>
                <li><a href="#trainers">教练</a></li>
                <li><a href="#about">关于我们</a></li>
                <li><a href="#contact">联系我们</a></li>
            </ul>
            <div class="menu-toggle">
                <span></span>
                <span></span>
                <span></span>
            </div>
        </div>
    </nav>
    <!-- 首页英雄区域 -->
    <section id="home" class="hero">
        <div class="hero-content">
            <h1>塑造更好的自己</h1>
            <p>专业教练,科学训练,让你的每一次汗水都不白流</p>
            <a href="#classes" class="btn">立即开始</a>
        </div>
    </section>
    <!-- 特色区域 -->
    <section class="features">
        <div class="container">
            <h2 class="section-title">为什么选择我们</h2>
            <div class="features-grid">
                <div class="feature-card">
                    <i class="fas fa-dumbbell"></i>
                    <h3>顶级设备</h3>
                    <p>引进国际一线健身器材,确保您在安全舒适的环境中训练。</p>
                </div>
                <div class="feature-card">
                    <i class="fas fa-user-tie"></i>
                    <h3>专业教练</h3>
                    <p>所有教练均持有国际认证,为您提供一对一的定制化指导。</p>
                </div>
                <div class="feature-card">
                    <i class="fas fa-clock"></i>
                    <h3>灵活时间</h3>
                    <p>24小时营业,多种课程时段,完美融入您的生活节奏。</p>
                </div>
            </div>
        </div>
    </section>
    <!-- 课程区域 -->
    <section id="classes" class="classes">
        <div class="container">
            <h2 class="section-title">热门课程</h2>
            <p class="section-subtitle">找到最适合你的训练方式</p>
            <div class="filter-buttons">
                <button class="filter-btn active" data-filter="all">全部</button>
                <button class="filter-btn" data-filter="yoga">瑜伽</button>
                <button class="filter-btn" data-filter="hiit">HIIT</button>
                <button class="filter-btn" data-filter="strength">力量</button>
            </div>
            <div class="classes-grid">
                <div class="class-card" data-category="yoga">
                    <img src="images/class-1.jpg" alt="瑜伽课程">
                    <div class="class-card-content">
                        <h3>流瑜伽</h3>
                        <p>结合呼吸与动作的流动序列,提升柔韧性与专注力。</p>
                        <div class="class-meta">
                            <span><i class="far fa-calendar"></i> 周一, 周三</span>
                            <span><i class="far fa-clock"></i> 19:00</span>
                        </div>
                    </div>
                </div>
                <div class="class-card" data-category="hiit">
                    <img src="images/class-2.jpg" alt="HIIT课程">
                    <div class="class-card-content">
                        <h3>燃脂HIIT</h3>
                        <p>高强度间歇训练,短时间内高效燃烧卡路里,挑战极限。</p>
                        <div class="class-meta">
                            <span><i class="far fa-calendar"></i> 周二, 周四</span>
                            <span><i class="far fa-clock"></i> 18:30</span>
                        </div>
                    </div>
                </div>
                <div class="class-card" data-category="strength">
                    <img src="images/class-3.jpg" alt="力量训练课程">
                    <div class="class-card-content">
                        <h3>综合力量</h3>
                        <p>系统性的力量训练,增强肌肉,塑造健美体型。</p>
                        <div class="class-meta">
                            <span><i class="far fa-calendar"></i> 周五, 周六</span>
                            <span><i class="far fa-clock"></i> 20:00</span>
                        </div>
                    </div>
                </div>
                <!-- 可以添加更多课程卡片 -->
            </div>
        </div>
    </section>
    <!-- 教练区域 -->
    <section id="trainers" class="trainers">
        <div class="container">
            <h2 class="section-title">明星教练团队</h2>
            <div class="trainers-grid">
                <div class="trainer-card">
                    <img src="images/coach-1.jpg" alt="教练李华">
                    <h3>李华</h3>
                    <p>国家级健身指导员,10年教学经验,专长于力量与体能训练。</p>
                    <div class="social-links">
                        <a href="#"><i class="fab fa-facebook"></i></a>
                        <a href="#"><i class="fab fa-instagram"></i></a>
                        <a href="#"><i class="fab fa-twitter"></i></a>
                    </div>
                </div>
                <div class="trainer-card">
                    <img src="images/coach-2.jpg" alt="教练王静">
                    <h3>王静</h3>
                    <p>瑜伽联盟认证导师,精通哈他、流瑜伽与阴瑜伽,课程治愈身心。</p>
                    <div class="social-links">
                        <a href="#"><i class="fab fa-facebook"></i></a>
                        <a href="#"><i class="fab fa-instagram"></i></a>
                        <a href="#"><i class="fab fa-twitter"></i></a>
                    </div>
                </div>
                <div class="trainer-card">
                    <img src="images/coach-3.jpg" alt="教练张伟">
                    <h3>张伟</h3>
                    <p>前职业运动员,HIIT训练专家,带你突破自我,达到巅峰状态。</p>
                    <div class="social-links">
                        <a href="#"><i class="fab fa-facebook"></i></a>
                        <a href="#"><i class="fab fa-instagram"></i></a>
                        <a href="#"><i class="fab fa-twitter"></i></a>
                    </div>
                </div>
            </div>
        </div>
    </section>
    <!-- 页脚 -->
    <footer class="footer">
        <div class="container">
            <p>&copy; 2025 FitLife 健身中心. 保留所有权利.</p>
            <p>地址:北京市朝阳区健身街88号 | 电话:400-123-4567</p>
        </div>
    </footer>
    <script src="js/script.js"></script>
</body>
</html>

如何使用和扩展

  1. 准备图片: 将您自己的图片放入 images 文件夹,并替换 src 属性中的路径。
  2. : 直接在 index.html 中修改文本、标题和链接。
  3. 调整颜色: 在 style.cssroot 部分,您可以轻松更改网站的主色调、辅助色等。
  4. 添加页面: 您可以基于此模板创建 classes.html (课程详情页)、trainers.html (教练详情页) 等,并共享 css/style.cssjs/script.js 文件。
  5. 增强功能:
    • 表单: 在“联系我们”部分添加一个联系表单。
    • 轮播图: 使用 Swiper.js 或纯 JS 实现首页图片轮播。
    • 动画: 使用 AOS (Animate On Scroll) 库为元素添加滚动时的进入动画。
    • 后端集成: 如果需要用户注册、课程预约等功能,可以将此静态模板与后端技术(如 Node.js, PHP, Python)结合。

这个模板为您提供了一个坚实的基础,您可以在此基础上进行深度定制和功能扩展,打造一个专业且吸引人的运动健身网站。

html5运动健身模板
(图片来源网络,侵删)
html5运动健身模板
(图片来源网络,侵删)