让div居中的方式的几种方法

Posted zch981964

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了让div居中的方式的几种方法相关的知识,希望对你有一定的参考价值。

让div水平居中的方式的几种方法。

文章目录


一、margin

第一种方式我们可以利用外边距属性来使div水平垂直居中

先来看一段有问题的代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>margin</title>
  <style>
    *
      margin: 0;
      padding: 0; 
    
    /* 父容器样式 */
    .container
      height: 800px;
      background-color: black;
    
    /* 子容器样式 */
    .son
      width: 300px;
      height: 300px;
      background-color: white;
      /* 水平垂直居中 */
      margin: 250px auto;
    
  </style>
</head>
<body>
    <!-- 父容器 -->
    <div class="container">
      <!-- 子容器 -->
      <div class="son"></div>
    </div>
</body>
</html>

效果

   可以看到,给子容器设置顶部外边距,连带父容器也被往下挤了,这是因为margin属性只有遇到边界才会"停下来"。边界就是border属性或者padding属性,因为父容器没有边界,所以子容器的外边距是相对父容器的父容器的,也就是body。所以我们想要让子容器相对父元素垂直居中,就要给父元素设置一个padding或者border。
正确的代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>margin</title>
  <style>
    *
      margin: 0;
      padding: 0; 
    
    /* 父容器样式 */
    .container
      height: 800px;
      background-color: black;
      border: 1px solid;
      /* padding: 1px; */
    
    /* 子容器样式 */
    .son
      width: 300px;
      height: 300px;
      background-color: blue;
      /* 水平垂直居中 */
      margin: 250px auto;
    
  </style>
</head>
<body>
    <!-- 父容器 -->
    <div class="container">
      <!-- 子容器 -->
      <div class="son"></div>
    </div>
</body>
</html>


margin:上下边距 左右边距;
要让div水平居中,就要设置左右边距为auto,自适应。
要让div垂直居中,就要计算上下边距了,垂直居中的上下边距为父容器高度的一半减去子容器高度的一半。

二、绝对定位

正确代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>绝对定位</title>
  <style>
    *
      margin: 0;
      padding: 0;
    
    /* 父容器 */
    .container
      height: 700px;
      position: relative;
      background-color: black;
    
    /* 子容器 */
    .son
      width: 300px;
      height: 300px;
      background-color: white;
      position:absolute;
      /* 水平垂直居中 */
      left: 0;
      right: 0;
      top: 0;
      bottom: 0;
      margin: auto;
    
  </style>
</head>
<body>
  <div class="container">
    <div class="son"></div>
  </div>
</body>
</html>

只要让子容器开启绝对定位,并且left、right、top、bottom全为0,margin:auto就能实现div水平垂直居中了。

三、子元素绝对定位父元素相对定位

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>子绝父相</title>
  <style>
    *
      margin: 0;
      padding: 0;
    
    /* 父容器 */
    .container
      height: 700px;
      background-color: black;
       /* 父容器开启相对定位*/
      position: relative;
    
    /* 子容器 */
    .son
      width: 300px;
      height: 300px;
      background-color: white;
      /* 子容器开启绝对定位*/
      position:absolute;
      /* 水平垂直居中 */
      top: 50%;
      margin-top: -150px;
      left: 50%;
      margin-left: -150px;
    
  </style>
</head>
<body>
  <div class="container">
    <div class="son"></div>
  </div>
</body>
</html>

给父容器开启相对定位,子元素开启绝对定位。
水平居中 left: 50%;margin-left: -150px;
垂直居中 top: 50%;margin-top: -150px;
margin的值是子容器宽度或高度一半的负值
水平方向我们一般使用left,垂直方向一般使用top,以免出现问题。

四、flex布局

正确代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>flex布局</title>
  <style>
    *
      margin: 0;
      padding: 0;
    
    /* 父容器 */
    .container
      height: 700px;
      background-color: black;
      /* 父容器开启flex布局 */
      display: flex;
      /* 水平垂直居中 */
      justify-content: center;
      align-items: center;
    
    /* 子容器 */
    .son
      width: 300px;
      height: 300px;
      background-color: white;
    
  </style>
</head>
<body>
  <div class="container">
    <div class="son"></div>
  </div>
</body>
</html>

给父容器开启flex布局,父容器就变成flex容器了,子容器就变成flex项目了。
利用flex布局控制项目水平方向和垂直方向排列的属性使div垂直水平居中。
justify-content: center;水平居中
align-items: center;垂直居中

总结

可能讲述得不清楚,能看懂就好了。

原文参考:https://blog.csdn.net/qq_57443373/article/details/120179047

让div盒子相对父盒子垂直居中的几种方法

div相对于父盒子垂直居中的几种方法,之前在网上看到很多种方法,确实说的很对,也很具体,但是我感觉对于初学者来说,一目了然是最重要的,所以,我把很高深的技巧,和很复杂的css样式都剔除掉,旨在让更多人能看懂。

具体事例方法如下:

   1.   其实这里的重点是,一定要给父盒子设置相对定位

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<style>

 #one{
width: 400px;
height: 400px;
border: 1px solid #000;
position: relative; //重点:必须给父元素设置相对定位
}

#two{
width: 200px;
height: 200px;
background-color: red;
position: absolute; // 给父元素设置相对定位
top: 50%;
left: 50%;
margin-left: -100px;
margin-top: -100px;

}



</style>
<body>
<div id="one">
<div id="two"></div>
</div>


</body>
</html>

 

   2.  不多说规则同上(只有思想不太一样)

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<style>
  #one{
width: 400px;
height: 400px;
border: 1px solid #000;
position: relative;
}
    #two{
width: 200px;
height: 200px;
background-color: red;
position: absolute;
margin: auto;
top: 0;
left: 0;
right: 0;
bottom: 0;
}



</style>
<body>
<div id="one">
<div id="two"></div>
<img src="" />
</div>


</body>
</html>

最后说一下 让<img>垂直定位的方法

以下是html结构:
<div id="one">
<div id="two"></div>
<img src="" />
</div>

css样式:

img {
    display:table-cell;
    text-align:center;
    vertical-align:middle;
}

相信很多初学者对display:table-cell不是太了解,下面我说一下:
display:table-cell属性就是让标签元素以表格单元格的形式呈现,类似于td标签。目前IE8+以及其他现代浏览器都是支持此属性
的,但是IE6/7只能对你说sorry了,这一事实也是大大制约了display:table-cell属性在实际项目中的应用。

希望对你有帮助
---不青春


以上是关于让div居中的方式的几种方法的主要内容,如果未能解决你的问题,请参考以下文章

CSS居中对齐的几种方式

CSS水平和垂直居中的几种实现方法

DIV居中的几种方法

HTML CSS中如何实现DIV中的图片水平垂直居中对齐

让div盒子相对父盒子垂直居中的几种方法

让div居中的方式的几种方法