本教程分为环境搭建、HTML 结构编写、CSS 样式布局、JavaScript 交互实现、部署上线等五大部分,覆盖从基础到进阶的核心知识点,并结合示例代码与最佳实践,帮助你快速上手并掌握前端开发基本技能。
个人主页是展示自我、分享作品的重要窗口。本教程将:
阅读完本教程后,你将具备独立构建、调试和发布静态个人主页的能力。
my-portfolio/
├── index.html
├── css/
│ └── styles.css
├── js/
│ └── main.js
└── assets/
├── images/
└── fonts/
index.html
:主页入口;css/styles.css
:主要样式文件;js/main.js
:JavaScript 逻辑;assets/
:存放图片、字体等静态资源。使用语义化标签能提升可访问性和 SEO 优化效果。例如:
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>我的个人主页</title>
<link rel="stylesheet" href="css/styles.css">
</head>
<body>
<header>…</header>
<nav>…</nav>
<main>…</main>
<footer>…</footer>
<script src="js/main.js"></script>
</body>
</html>
<!DOCTYPE html>
声明 HTML5 文档类型;<meta charset="UTF-8">
指定字符编码;<meta name="viewport">
实现移动端适配(MDN Web Docs)。<h1>
~<h6>
;<p>
;<a href="…">
;<ul>
、<ol>
与 <li>
;<img src="…" alt="…">
;<div>
与 <section>
、<article>
等语义化容器(MDN Web Docs)。* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Arial', sans-serif;
line-height: 1.6;
background: #f7f7f7;
color: #333;
}
box-sizing: border-box;
简化盒模型计算;Flexbox 用于一维布局,能轻松实现水平居中、垂直对齐等常见需求:
.nav {
display: flex;
justify-content: center;
align-items: center;
gap: 20px;
}
display: flex
将容器设为弹性布局;justify-content
与 align-items
分别控制主轴和交叉轴对齐方式(CSS-Tricks)。Grid 适合二维布局,能构建复杂的响应式网格系统:
.portfolio {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
grid-gap: 20px;
}
repeat(auto-fit, minmax())
根据容器宽度自动适配列数;grid-gap
控制行列间距。使用媒体查询实现针对不同设备的样式调整:
@media (max-width: 768px) {
.nav {
flex-direction: column;
}
}
示例:点击“返回顶部”按钮平滑滚动:
const topBtn = document.getElementById('top-btn');
topBtn.addEventListener('click', () => {
window.scrollTo({ top: 0, behavior: 'smooth' });
});
addEventListener
注册事件监听器;window.scrollTo
实现滚动位置控制(JavaScript教程)。借助 ES6 模块语法,将功能拆分到不同文件,提高可维护性:
// utils.js
export function formatDate(date) { /* … */ }
// main.js
import { formatDate } from './utils.js';
export
与 import
简化模块引用与复用(JavaScript教程)。使用 fetch
向后端接口请求数据,并动态渲染:
fetch('https://api.example.com/projects')
.then(res => res.json())
.then(data => renderProjects(data))
.catch(err => console.error(err));
fetch
支持 Promise,便于链式调用与错误处理。Netlify 提供免配置、一键托管静态站点的服务。
每次向主分支推送代码,Netlify 会触发自动构建与部署。你还可以开启 Deploy Preview 功能,生成 PR 预览环境,便于团队评审与测试。
在 Netlify 仪表盘中,可绑定自定义域名并一键启用免费的 Let’s Encrypt SSL 证书,保证站点安全与访问速度。
本教程从环境搭建到页面结构、从样式布局到交互脚本,再到部署上线,涵盖了构建个人主页所需的核心技术与实践。掌握这些内容后,你便能灵活运用原生前端技术,高效打造符合自己风格的个人作品集。希望你能在实战中不断迭代与优化,打造一份既美观又实用的个人主页。
持续学习:
版权说明:如非注明,本站文章均为 扬州驻场服务-网络设备调试-监控维修-南京泽同信息科技有限公司 原创,转载请注明出处和附带本文链接。
请在这里放置你的在线分享代码