【CSS布局】响应式设计原则以及双飞翼布局&圣杯布局

历史小剧场

温体仁未必是奸臣,钱谦益未必是好人,不需要惊讶,历史往往跟你所想的并不一样。英雄可以写成懦夫,能臣可以写成奸臣,史实并不重要,重要的是,谁来写。----《明朝那些事儿》

响应式设计原则

  1. 移动优先原则;
  2. 内容优先;
  3. 灵活布局;
  4. 图片和资源;
  5. 交互和性能

双飞翼布局

特点:两侧固定,中间自适应

效果:

传统方案实现

浮动+calc()函数

html 复制代码
<style>
	 * {
        margin: 0;
         padding: 0;
     }
	.container {
        min-width: 100%;
     }
     .container div {
         float: left;
         padding: 20px;
         text-align: center;
     }
     .center {
         width: calc(100% - 400px - 20 * 6px);
         background-color: red;
     }
     .left {
         width: 200px;
         background-color: yellow;
     }
     .right {
         width: 200px;
         background-color: green;
     }
</style>
<div class="container">
    <div class="left">左侧内容</div>
    <div class="center">中间内容</div>
    <div class="right">右侧内容</div>
</div>
Flex布局实现
css 复制代码
 .container {
   display: flex;
    justify-content: space-between;
}
.container div {
    padding: 20px;
    text-align: center;
}
.left {
    width: 200px;
    background-color: red;
}
.right {
    width: 200px;
    background-color: greenyellow;
}
.center {
    background-color: gold;
    flex: 1;
}

圣杯布局

特点:

  • 头部和底部固定;
  • 中间部分自适应;
  • 且中间部分里的三个部分遵循双飞翼布局原则
    效果:
传统方案实现

浮动+calc()函数

html 复制代码
<style>
	 * {
        margin: 0;
         padding: 0;
     }
     header, footer {
        text-align: center;
        height: 40px;
        line-height: 40px;
        width: 100%;
    }
    header {
        background-color: skyblue;
    }
    footer {
        background-color: salmon;
    }
    main {
        height: calc(100vh - 80px);
    }
    main > div {
        float: left;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    main .left {
        width: 200px;
        background-color: red;
    }
    main .center {
        background-color: deepskyblue;
        width: calc(100% - 400px);
    }
    main .right {
        width: 200px;
        background-color: greenyellow;
    }
</style>
<header>header</header>
<main>
    <div class="left">左侧内容</div>
    <div class="center">中间内容</div>
    <div class="right">右侧内容</div>
</main>
<footer>footer</footer>
Flex布局实现
css 复制代码
header, footer {
    height: 50px;
    line-height: 50px;
    text-align: center;
}
header {
    background-color: slateblue;
}
footer {
    background-color: slategray;
}
main {
    height: calc(100vh - 100px);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
main div {
    display: flex;
    align-items: center;
    justify-content: center;
}
main .left, main .right {
    width: 200px;
    flex-shrink: 0;
}
main .left {
    background-color: red;
}
main .right {
    background-color: greenyellow
}
main .center {
    background-color: skyblue;
    flex-grow: 1;
}
相关推荐
双向3321 分钟前
RAG的下一站:检索增强生成如何重塑企业知识中枢?
前端
拖拉斯旋风24 分钟前
从零开始:使用 Ollama 在本地部署开源大模型并集成到 React 应用
前端·javascript·ollama
asing31 分钟前
🤯 为什么我的收银台在鸿蒙系统“第一次返回”死活拦不住?一次差点背锅的排查实录
前端·harmonyos
德育处主任33 分钟前
『NAS』在群晖部署图片压缩工具-Squoosh
前端·javascript·docker
Hao_Harrision35 分钟前
50天50个小项目 (React19 + Tailwindcss V4) ✨| ThreeDBackgroundBoxes(3D背景盒子组件)
前端·3d·typescript·react·tailwindcss·vite7
加个鸡腿儿38 分钟前
经验分享2:SSR 项目中响应式组件的闪动陷阱与修复实践
前端·css·架构
心.c1 小时前
如何基于 RAG 技术,搭建一个专属的智能 Agent 平台
开发语言·前端·vue.js
智航GIS1 小时前
10.7 pyspider 库入门
开发语言·前端·python
华仔啊2 小时前
写 CSS 用 px?这 3 个单位能让页面自动适配屏幕
前端·css
Van_captain2 小时前
rn_for_openharmony常用组件_Breadcrumb面包屑
javascript·开源·harmonyos