- 语义化 HTML5 结构:清晰的代码,利于 SEO 和可访问性。
- 现代 CSS3 样式:使用 Flexbox/Grid 布局,实现响应式设计。
- 平滑滚动和导航高亮:提升用户体验。
- 一个简单的 JavaScript 交互:实现导航栏滚动时的样式变化。
最终效果预览
这个模板将包含以下几个经典部分:

- 导航栏:固定在顶部,滚动时会改变样式。
- 英雄区:网站的欢迎横幅。
- 关于我们:介绍公司或项目。
- 服务/特色:展示核心功能。
- 作品集/展示:用网格布局展示项目。
- 联系方式:简单的联系表单或信息。
- 页脚:版权和社交媒体链接。
第一步:HTML 结构 (index.html)
这是整个网站的骨架,使用了 HTML5 的语义化标签,让结构更清晰。
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">我的单页网站</title>
<!-- 引入外部 CSS 文件 -->
<link rel="stylesheet" href="style.css">
<!-- 引入字体图标库 (Font Awesome) -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
</head>
<body>
<!-- 导航栏 -->
<header id="navbar">
<nav class="container">
<a href="#" class="logo">我的Logo</a>
<ul class="nav-links">
<li><a href="#home">首页</a></li>
<li><a href="#about">lt;/a></li>
<li><a href="#services">服务</a></li>
<li><a href="#portfolio">作品</a></li>
<li><a href="#contact">联系</a></li>
</ul>
<div class="burger">
<div class="line1"></div>
<div class="line2"></div>
<div class="line3"></div>
</div>
</nav>
</header>
<main>
<!-- 英雄区 -->
<section id="home">
<div class="hero-content container">
<h1>欢迎来到我的网站</h1>
<p>这里是您的副标题,用简短的语言描述您的网站。</p>
<a href="#about" class="cta-button">了解更多</a>
</div>
</section>
<!-- 关于我们 -->
<section id="about">
<div class="container">
<h2>关于我们</h2>
<p>这里是关于我们公司的详细介绍,您可以在这里分享您的使命、愿景和价值观,让访问者更好地了解您是谁,以及您为什么与众不同。</p>
</div>
</section>
<!-- 服务 -->
<section id="services">
<div class="container">
<h2>我们的服务</h2>
<div class="services-grid">
<div class="service-item">
<i class="fas fa-code"></i>
<h3>Web 开发</h3>
<p>提供高质量的网站和 Web 应用程序开发服务。</p>
</div>
<div class="service-item">
<i class="fas fa-paint-brush"></i>
<h3>UI/UX 设计</h3>
<p>创造美观且用户友好的界面设计。</p>
</div>
<div class="service-item">
<i class="fas fa-mobile-alt"></i>
<h3>移动应用</h3>
<p>开发适用于 iOS 和 Android 的原生应用。</p>
</div>
</div>
</div>
</section>
<!-- 作品集 -->
<section id="portfolio">
<div class="container">
<h2>作品展示</h2>
<div class="portfolio-grid">
<div class="portfolio-item">
<img src="https://via.placeholder.com/400x300" alt="项目1">
<h3>项目一</h3>
<p>项目描述</p>
</div>
<div class="portfolio-item">
<img src="https://via.placeholder.com/400x300" alt="项目2">
<h3>项目二</h3>
<p>项目描述</p>
</div>
<div class="portfolio-item">
<img src="https://via.placeholder.com/400x300" alt="项目3">
<h3>项目三</h3>
<p>项目描述</p>
</div>
</div>
</div>
</section>
<!-- 联系方式 -->
<section id="contact">
<div class="container">
<h2>联系我们</h2>
<form action="#" method="post">
<input type="text" name="name" placeholder="您的姓名" required>
<input type="email" name="email" placeholder="您的邮箱" required>
<textarea name="message" placeholder="您的留言" rows="5" required></textarea>
<button type="submit" class="cta-button">发送消息</button>
</form>
</div>
</section>
</main>
<!-- 页脚 -->
<footer>
<div class="container">
<p>© 2025 我的公司. 保留所有权利.</p>
<div class="social-links">
<a href="#"><i class="fab fa-facebook"></i></a>
<a href="#"><i class="fab fa-twitter"></i></a>
<a href="#"><i class="fab fa-linkedin"></i></a>
<a href="#"><i class="fab fa-github"></i></a>
</div>
</div>
</footer>
<!-- 引入外部 JavaScript 文件 -->
<script src="script.js"></script>
</body>
</html>
第二步:CSS 样式 (style.css)
这是网站的“外衣”,负责所有视觉呈现,包括布局、颜色、字体和响应式设计。
/* --- 全局样式和变量 --- */
:root {
--primary-color: #3498db;
--secondary-color: #2c3e50;
--text-color: #333;
--light-bg: #ecf0f1;
--white: #fff;
--max-width: 1200px;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
scroll-behavior: smooth; /* 平滑滚动 */
}
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
line-height: 1.6;
color: var(--text-color);
}
.container {
max-width: var(--max-width);
margin: 0 auto;
padding: 0 20px;
}
h1, h2, h3 {
margin-bottom: 1rem;
line-height: 1.2;
}
p {
margin-bottom: 1rem;
}
.cta-button {
display: inline-block;
background-color: var(--primary-color);
color: var(--white);
padding: 12px 25px;
text-decoration: none;
border-radius: 5px;
transition: background-color 0.3s ease;
}
.cta-button:hover {
background-color: #2980b9;
}
/* --- 导航栏 --- */
header {
position: fixed;
top: 0;
width: 100%;
background-color: var(--white);
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
z-index: 1000;
transition: all 0.3s ease;
}
header.scrolled {
padding: 10px 0;
background-color: rgba(255, 255, 255, 0.95);
}
nav {
display: flex;
justify-content: space-between;
align-items: center;
padding: 20px 0;
}
.logo {
font-size: 1.5rem;
font-weight: bold;
color: var(--secondary-color);
text-decoration: none;
}
.nav-links {
display: flex;
list-style: none;
}
.nav-links li a {
color: var(--text-color);
text-decoration: none;
padding: 10px 15px;
transition: color 0.3s ease;
}
.nav-links li a:hover {
color: var(--primary-color);
}
/* --- 汉堡菜单 (移动端) --- */
.burger {
display: none;
cursor: pointer;
}
.burger div {
width: 25px;
height: 3px;
background-color: var(--text-color);
margin: 5px 0;
transition: all 0.3s ease;
}
/* --- 各个区块 --- */
section {
padding: 80px 0;
}
#home {
height: 100vh;
background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)), url('https://via.placeholder.com/1920x1080') no-repeat center center/cover;
color: var(--white);
display: flex;
align-items: center;
text-align: center;
}
#home h1 {
font-size: 3rem;
margin-bottom: 1rem;
}
#about {
background-color: var(--light-bg);
text-align: center;
}
#services {
text-align: center;
}
.services-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 30px;
margin-top: 40px;
}
.service-item {
padding: 30px;
background-color: var(--white);
border-radius: 8px;
box-shadow: 0 5px 15px rgba(0,0,0,0.1);
transition: transform 0.3s ease;
}
.service-item:hover {
transform: translateY(-10px);
}
.service-item i {
font-size: 2.5rem;
color: var(--primary-color);
margin-bottom: 20px;
}
#portfolio {
text-align: center;
}
.portfolio-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 30px;
margin-top: 40px;
}
.portfolio-item {
overflow: hidden;
border-radius: 8px;
box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}
.portfolio-item img {
width: 100%;
height: 250px;
object-fit: cover;
transition: transform 0.3s ease;
}
.portfolio-item:hover img {
transform: scale(1.1);
}
.portfolio-item h3, .portfolio-item p {
padding: 20px;
background-color: var(--white);
}
#contact {
background-color: var(--light-bg);
text-align: center;
}
#contact form {
max-width: 600px;
margin: 0 auto;
}
#contact .form-group {
margin-bottom: 20px;
text-align: left;
}
#contact input,
#contact textarea {
width: 100%;
padding: 12px;
border: 1px solid #ccc;
border-radius: 5px;
font-family: inherit;
}
/* --- 页脚 --- */
footer {
background-color: var(--secondary-color);
color: var(--white);
text-align: center;
padding: 30px 0;
}
.social-links a {
color: var(--white);
margin: 0 10px;
font-size: 1.2rem;
transition: color 0.3s ease;
}
.social-links a:hover {
color: var(--primary-color);
}
/* --- 响应式设计 --- */
@media (max-width: 768px) {
.nav-links {
position: absolute;
right: 0;
top: 70px;
background-color: var(--white);
width: 100%;
flex-direction: column;
align-items: center;
transform: translateY(-150%);
transition: transform 0.3s ease-in-out;
box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}
.nav-links.active {
transform: translateY(0);
}
.burger {
display: block;
}
#home h1 {
font-size: 2rem;
}
}
第三步:JavaScript 交互 (script.js)
这里添加一些简单的交互,让网站“活”起来。
// 1. 导航栏滚动效果
window.addEventListener('scroll', function() {
const navbar = document.getElementById('navbar');
if (window.scrollY > 50) { // 当滚动超过50px时
navbar.classList.add('scrolled');
} else {
navbar.classList.remove('scrolled');
}
});
// 2. 汉堡菜单点击效果
const burger = document.querySelector('.burger');
const navLinks = document.querySelector('.nav-links');
burger.addEventListener('click', function() {
navLinks.classList.toggle('active');
});
// 3. 关闭移动端菜单当点击链接时
document.querySelectorAll('.nav-links a').forEach(link => {
link.addEventListener('click', () => {
navLinks.classList.remove('active');
});
});
// 4. 表单提交提示 (简单示例,实际开发中需要后端支持)
const contactForm = document.querySelector('#contact form');
if (contactForm) {
contactForm.addEventListener('submit', function(e) {
e.preventDefault(); // 阻止表单默认提交行为
// 这里可以添加表单验证逻辑
// 显示成功消息
const successMessage = document.createElement('p');
successMessage.textContent = '消息已发送!我们会尽快与您联系。';
successMessage.style.color = 'green';
successMessage.style.marginTop = '20px';
// 清空表单
contactForm.reset();
// 将消息插入到表单后面
contactForm.appendChild(successMessage);
// 5秒后移除消息
setTimeout(() => {
successMessage.remove();
}, 5000);
});
}
如何使用这个模板
- 创建文件:在你的项目文件夹中创建三个文件:
index.html、style.css和script.js。 - 复制代码:将上面的 HTML、CSS 和 JavaScript 代码分别粘贴到对应的文件中。
- :
index.html: 修改title、logo、<h1>,<p>标签中的文字,以及图片的src属性为你自己的内容。style.css: 修改root中的颜色变量(--primary-color,--secondary-color等)来改变网站的主题色,也可以修改字体、间距等。script.js: 可以根据需要添加更复杂的交互逻辑。
- 打开预览:用浏览器打开
index.html文件,你就可以看到网站的效果了。
进阶建议
- CSS 框架:如果你希望更快地开发,可以考虑使用 Bootstrap 或 Tailwind CSS 等框架,它们提供了大量现成的组件和工具类。
- JavaScript 库:对于更复杂的动画和交互,可以使用 GSAP 或 AOS (Animate On Scroll) 库。
- 图片优化:使用
https://via.placeholder.com/只是临时方案,请务必替换为你自己的优化过的图片,以提高网站加载速度。 - 表单后端:
script.js中的表单提交只是一个前端模拟,要让表单真正能发送邮件,你需要一个后端服务(如 Node.js, PHP, Python)或使用第三方服务(如 Formspree, Getform)。
这个模板为你提供了一个坚实的基础,你可以在此基础上进行无限的扩展和定制,祝你开发愉快!


