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

(图片来源网络,侵删)
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>© 2025 FitLife 健身中心. 保留所有权利.</p>
<p>地址:北京市朝阳区健身街88号 | 电话:400-123-4567</p>
</div>
</footer>
<script src="js/script.js"></script>
</body>
</html>
如何使用和扩展
- 准备图片: 将您自己的图片放入
images文件夹,并替换src属性中的路径。 - : 直接在
index.html中修改文本、标题和链接。 - 调整颜色: 在
style.css的root部分,您可以轻松更改网站的主色调、辅助色等。 - 添加页面: 您可以基于此模板创建
classes.html(课程详情页)、trainers.html(教练详情页) 等,并共享css/style.css和js/script.js文件。 - 增强功能:
- 表单: 在“联系我们”部分添加一个联系表单。
- 轮播图: 使用 Swiper.js 或纯 JS 实现首页图片轮播。
- 动画: 使用 AOS (Animate On Scroll) 库为元素添加滚动时的进入动画。
- 后端集成: 如果需要用户注册、课程预约等功能,可以将此静态模板与后端技术(如 Node.js, PHP, Python)结合。
这个模板为您提供了一个坚实的基础,您可以在此基础上进行深度定制和功能扩展,打造一个专业且吸引人的运动健身网站。

(图片来源网络,侵删)

(图片来源网络,侵删)
