• 如何使一个盒子水平垂直居中以及如何实现双飞翼(圣杯)布局?


    一、如何使一个盒子水平垂直居中

    方法一:利用定位

    html代码片段:

    <body>
    <div class="parent">
    <div class="child">我是子元素</div>
    </div>
    </body>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    方法二:利用 margin:auto

    html代码片段:

    <body>
    <div class="parent">
    <div class="child">我是子元素</div>
    </div>
    </body>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    
    Document
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    方法三:利用 display:table-cell

    html代码片段:

    <body>
    <div class="parent">
    <div class="child">我是子元素</div>
    </div>
    </body>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    方法四:利用 display:flex;设置垂直水平都居中

    html代码片段:

    <body>
    <div class="parent">
    <div class="child">我是子元素</div>
    </div>
    </body>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    方法五:计算父盒子与子盒子的空间距离(这跟方法一是一个道理)

    html代码片段:

    <body>
    <div class="parent">
    <div class="child">我是子元素</div>
    </div>
    </body>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    方法六:利用 transform

    html代码片段:

    <body>
    <div class="parent">
    <div class="child">我是子元素</div>
    </div>
    </body>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    二、如何实现双飞翼(圣杯)布局?

    1、利用定位实现两侧固定中间自适应

    		1、父盒子设置左右 padding 值
    		2、给左右盒子的 width 设置父盒子的 padding 值,然后分别定位到 padding 处
    		3、中间盒子自适应
    
    • 1
    • 2
    • 3

    html代码片段:

    <div class="father">
     <div class="left"></div>
     <div class="center"></div>
     <div class="right"></div>
    </div>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    2、利用 flex 布局实现两侧固定中间自适应

    		1、父盒子设置 display:flex;
    		2、左右盒子设置固定宽高
    		3、中间盒子设置 flex:1
    
    • 1
    • 2
    • 3

    html代码片段:

    <div class="father">
     <div class="left"></div>
     <div class="center"></div>
     <div class="right"></div>
     </div>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    3、利用 bfc 块级格式化上下文, 实现两侧固定中间自适应

    	1、左右固定宽高,进行浮动
    	2、中间 overflow: hidden;
    
    • 1
    • 2

    html代码片段:

    <!-- 注意:left 和 right 必须放在 center 前面 -->
    <div class="father">
    <div class="left"></div>
    <div class="right"></div>
    <div class="center"></div>
    </div>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    css代码片段:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
  • 相关阅读:
    股票L1和L2都代表是什么意思?
    一文了解Web3.0真实社交先驱ERA
    requests爬虫详解
    模拟一个火车站售票小例子
    JavaScript的学习之BOM和DOM,就这一篇就OK了!(超详细)
    数组的基本概念和存储结构
    开发视频会议系统:使用GPU解码渲染视频
    数据结构第三部分——树和二叉树(C语言版)
    火山引擎 DataTester 背后,抖音的名字原来是 AB 测试来的
    程序员的出路是什么?
  • 原文地址:https://blog.csdn.net/weixin_50370865/article/details/128192975