用 flexbox 布局简历主体结构,移动端垂直堆叠、桌面端并排,配合断点控制字体、间距和图片尺寸,统一使用 rem 单位,完善打印样式与动效降级。

用 flexbox 布局简历主体结构,别碰 float 和 table
响应式简历页面的核心是清晰的视觉流与断点控制,flexbox 能天然支持横向/纵向切换、对齐和顺序重排,而 float 在现代布局中已失效(尤其在 min-width 变化时容易塌陷),table 则语义错误且难以响应。
典型结构建议用三层嵌套:body → .container → .section(如 .header、.main、.sidebar)。移动端默认垂直堆叠,桌面端让 .main 和 .sidebar 并排:
.container {
display: flex;
flex-direction: column;
}
@media (min-width: 768px) {
.container {
flex-direction: row;
}
.main {
flex: 3;
}
.sidebar {
flex: 1;
}
}
- 避免给
flex子项设固定width,否则在小屏下会溢出;用flex比例或max-width控制伸缩边界 -
flex-wrap: wrap在简历里基本不用——内容长度可控,强行换行反而破坏模块完整性 - 注意
align-items默认是stretch,若侧边栏高度不一致,加align-items: flex-start防止拉伸
用 @media 控制字体、间距和图片尺寸,而不是重写整个布局
响应式不是“写两套 CSS”,而是渐进增强。字体大小、padding、margin 和头像 img 尺寸是最常随屏幕变化的三类属性。
推荐断点只设两个:768px(平板竖屏起)和 1024px(横屏或大屏),覆盖主流设备。不要为 iPhone SE 单独写媒体查询——它会继承 768px 以下规则,足够清晰。
立即学习“前端免费学习笔记(深入)”;
@media (max-width: 767px) {
h1 { font-size: 1.8rem; }
.contact-item { margin-bottom: 0.5rem; }
.profile-img { width: 120px; height: 120px; }
}
@media (min-width: 768px) and (max-width: 1023px) {
h1 { font-size: 2.2rem; }
.profile-img { width: 140px; height: 140px; }
}
- 所有文字单位统一用
rem,根字号用html { font-size: 100%; }保证可访问性缩放生效 - 图片别用
width: 100%+height: auto粗暴拉伸,简历头像应保持比例,优先用object-fit: cover裁切 - 避免在媒体查询里重复定义颜色、边框等静态样式——提取到基础选择器中
打印样式用 @media print 关闭无关元素,但保留语义结构
用户可能导出 PDF 或直接打印简历,此时轮播图、图标字体、阴影、背景色全要禁用,但不能删掉 h2、ul、time 这类语义标签——它们影响可读性和辅助工具解析。
@media print {
* { box-shadow: none !important; text-shadow: none !important; }
.no-print, .nav, .social-links { display: none !important; }
body { font-size: 12pt; line-height: 1.4; color: #000; background: #fff; }
a { color: #000; text-decoration: none; }
img { max-width: 100% !important; height: auto !important; }
}- 不要用
display: none隐藏整段经历(比如.experience),这会让打印版简历空白——只隐藏装饰性容器 -
background-color和background-image必须显式设为transparent或none,否则某些浏览器打印时仍渲染 - 测试打印效果前,先在 Chrome DevTools 的 Rendering 面板勾选
Emulate CSS media: print
用 prefers-reduced-motion 降低动画干扰,但别禁用所有过渡
简历不是动画演示页。用户开启“减少运动”系统偏好时,CSS 动画和过渡应弱化,但不能让交互完全僵硬——比如 hover 下划线、按钮轻微变色这类微反馈仍可保留。
关键原则:只对非必要动效做降级,且用 reduce 值判断,而非监听 JS 事件。
@media (prefers-reduced-motion: reduce) {
* {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01s !important;
}
/* 允许语义化过渡保留 */
a:hover {
text-decoration: underline;
}
}- 别在
@media (prefers-reduced-motion)里重置transform或opacity——这会导致元素突然跳变,反而更干扰 - 如果用了
scroll-behavior: smooth,也需在该媒体查询中设为auto,否则锚点跳转会卡顿 - 第三方图标字体(如 Font Awesome)的旋转动画(
fa-spin)必须被该规则捕获并停用,否则打印或低配设备上会持续闪烁
实际部署时最容易被忽略的是字体加载策略和 SVG 图标 fallback:本地字体没加载完时,font-display: swap 能防止文字长时间空白,而 SVG 图标若用 引用外部 sprite,需确保路径在所有环境下都可访问——相对路径在子目录打开时会 404。










