整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

css篇-前端面试中常问的div居中方法

上又要到秋招的时候了,又有不少人打算换工作了。前端在面试中总会被问到的一道基础题div居中方法,这里给大家总结一下都有哪些常用的方法。

绝对定位

  • 父级元素(parent)采用相对定位(relative),需要居中的元素(demo)采用绝对定位(absolute)。
  • 居中元素向上偏移50%,向左偏移50%,此时左顶点位于中心,不过我们需要的是整体居中,所以在偏移自身一半的宽高。(如下图)

还未偏移一半自身宽高

<style>
    .parent {
      position: relative;
      width: 500px;
      height: 500px;
      border: solid red 1px;
    }
    .demo {
      position: absolute;
      width: 100px;
      height: 100px;
      border: solid blue 1px;
      top: 50%;
      left: 50%;
      margin-top: -50px;
      margin-left: -50px;
    }
  </style>
  <body>
    <div class="parent">
      <div class="demo"></div>
    </div>
  </body>

弹性方法居中

通过flex弹性布局设置垂直居中和水平居中

  <style>
    .parent {
      width: 500px;
      height: 500px;
      border: solid red 1px;
      display: flex;
      // 垂直,水平居中
      align-items: center;
      justify-content: center;
    }
    .demo {
      width: 100px;
      height: 100px;
      border: solid blue 1px;
    }
  </style>
  <body>
    <div class="parent">
      <div class="demo"></div>
    </div>
  </body>

使用transform居中

在子元素不知道自身宽高情况,使用transform进行比偏移。

  <style>
    .parent {
      position: relative;
      width: 500px;
      height: 500px;
      border: solid red 1px;
    }
    .demo {
      position: absolute;
      border: solid blue 1px;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
    }
  </style>
  <body>
    <div class="parent">
      <div class="demo">居中</div>
    </div>
  </body>

以上3种是常用的方法,当然还有其他居中方法比如grid布局,table-cell布局等。

前端面试中,CSS相关的问题一般不会问的太多,但是有一个问题经常被选为面试题。那就是:div 水平垂直居中你有哪些办法?

这道题可以考察候选人对CSS布局方式的理解,而且非常贴近日常工作,比较适合作为面试题。今天我就帮大家梳理一下CSS实现div水平垂直居中的方法,建议收藏。


为了演示,首先创建两个嵌套的 div,然后设置一下大小和背景颜色这样比较容易看出效果。代码如下:

// html
<div class="outer outer-box">
  <div class="inner inner-box"></div>
</div>

// css
<style>
.outer {
  height: 100px;
  width: 100px;
  background-color: royalblue;
}
.inner {
  height: 50px;
  width: 50px;
  background-color: red;
}
<style>

设置完的效果就是这样,然后我们需要把内部的div 水平垂直居中。准备就绪,正式开始。我们分别使用 Flex 布局,Position布局, Grid布局三种方式。


flex布局

Flex 是Flexible Box的缩写,意为”弹性布局”。Flexible Box 模型是一种一维的布局模型,一次只能处理一个维度上的布局。flex布局有两根轴线,主轴和交叉轴。flex就是根据这两个轴线布局元素。

1.1 对外层div设置flex布局

在外层 div 上设置 justify-content: center; align-items: center; 属性, display 设置为 flex。即可实现水平垂直居中。

1.2 内外div分别设置


结果如下图:

Flex实现水平处置居中


Position布局

Position布局是传统的布局方式,position属性指定定位方式,利用CSS盒模型实现定位布局。

2.1 内部div使用 margin 属性居中

2.2 内部 div 使用 transform 属性居中

实现结果如下:

Grid布局

Grid(网格)布局被称为最强大的CSS布局方案,它可以将一个页面划分为几个主要区域,以及定义这些区域的大小、位置、层次等关系。

上面这种布局,Grid非常擅长。Flex布局属于一维布局,Grid布局可以将容器分为行和列,对单元格进行布局,属于二维布局。


3.1 外层div使用 place-content 属性

3.2 外层div使用Grid布局

3.3 内外div分别设置

实现结果如下:

总结

常见的问题也不见得简单,前端知识还是常学常新的。了解不同类型的CSS布局方式,对处理实际问题也很有帮助。

以上就是CSS实现div水平垂直居中的7种方式。如果你有别的方式,欢迎和大家一起分析。

如果觉得文章对您有帮助,欢迎收藏,转发~

文翻译自 How to Center a Div Using CSS Grid,作者:Fimber Elemuwa, Ralph Mason。 略有删改

在本文中,我们将介绍使用CSS Grid在水平和垂直方向上居中div的五种方法,当然这些技术可用于任何类型的元素。

初始化

我们首先创建一个容器,其中包含一个简单的div元素,我们将使用它来演示这些居中方法。下面是HTML:

<article>
  <div></div>
</article>

下面是我们的初始CSS:

article {
  width: 100%;
  min-height: 100vh;
  background: black;
  display: grid;
}

div {
  width: 200px;
  background: yellow;
  height: 100px;
}

在下面所有的例子中,我们将使用display: grid属性。这将<article>元素建立为网格容器,并为该容器生成块级网格。我们已经将网格容器设置为宽(width: 100%)和高(min-height: 100vw),这样我们的div就有足够的空间在其中移动。

接下来让我们来看看将div居中的各种方法。

1.使用 CSS Grid 和 place-self 将Div居中

place-self属性提供了一种简单的方法来水平和垂直居中网格项。它用于将网格项置于其网格单元格的中心。

将div居中就像这样简单:

article {
  display: grid;
}

div {
  place-self: center;
}

place-self属性是justify-self(水平)和align-self(垂直)属性的简写。

使用place-self对于在网格内居中单个项目特别有用,因为它使其他网格项目可以自由地以不同的方式定位。但这并不是使用Grid使元素居中的唯一方法,继续看看其他的一些方法。

2.使用 CSS Grid 和 place-items 居中Div

place-items属性是justify-items(水平)和align-items(垂直)的简写。这些属性应用于网格容器而不是每个网格项,当我们希望所有网格项具有相同的位置时,这些属性非常有用。

将以下CSS代码添加到父容器:

article {
  display: grid;
  place-items: center;
}

我们可以基于初始代码添加更多的div元素,看看会发生什么。结果是每个div将在其网格单元格内水平和垂直居中,如下图所示(通过浏览器的网格检查器)。

3.使用 place-content 居中Div

place-content属性是justify-content(水平)和align-content(垂直)的简写。虽然place-selfplace-items控制网格项如何放置在其指定的网格单元格中,但place-content指定网格容器的整个内容应如何对齐(即,所有网格项被视为一个组)。在我们的演示中,只有一个网格项(我们的单个黄色div),因此我们也可以使用place-content将其置于其容器的中心。

将以下CSS代码添加到父容器:

article {
  display: grid;
  place-content: center;
}

这里有几点需要注意。到目前为止,在所有的例子中我们都使用了center的值。但是到目前为止,我们已经探索的每个属性都有各种其他的放置物品的值。place-content有很多值,另外两个值也可以用于居中我们的div:space-aroundspace-evenly

此外,在我们的简单例子中,一个div在容器中居中,我们甚至可以混合和匹配我们上面看到的属性。我们可以使用justify-contentalign-items来居中div,有兴趣的可以尝试看看。

4.使用 CSS Grid 和 Auto Margins 居中

像往常一样,我们将使用display: grid来定位父容器。我们还将使用margin: auto为div指定自动边距。这使浏览器自动计算div周围的可用空间,并在其网格单元格内垂直和水平划分,将div放置在中间:

article {
  display: grid;
}

div {
  margin: auto;
}

5.使用 CSS Grid 网格区域居中div

最后一个方法我们将深入探讨Grid布局的强大功能,因为我们将研究两种方法来将div居中放置在具有多行和多列的网格中。

以下是我们的基本CSS:

article {
  display: grid;
  grid-template-columns: 1fr 200px 1fr;
  grid-template-rows: 1fr 100px 1fr;
}

div {
  background: yellow;
  grid-column: 2;
  grid-row: 2;
}

我们显式地布局了一个网格,中间有一个区域来放置我们的div。我们现在甚至不需要在div上设置尺寸,因为网格轨迹会处理这个问题。我们在网格的中间指定一个网格单元格,其宽度为200px,高度为100px,然后我们告诉div从第二条网格线和第二条行线开始。(默认情况下,它将仅跨到每个方向上的下一条轴网线。)div元素被很好地放置在其容器的中心,如下所示。

下图显示了位于其网格轨迹内的div。

网格布局提供了各种不同的方法来实现这一结果。最后我们做与上面相同的事情,但这次为我们的div使用一个命名区域:

article {
  display: grid;
  grid-template-columns: 1fr 200px 1fr;
  grid-template-rows: 1fr 100px 1fr;
  grid-template-areas: ".  .  ."
                       ". box ."
                       ".  .  .";
}

div {
  background: yellow;
  grid-area: box;
}

在这里,我们设置一个名为grid-area的box,然后描述它应该位于网格上的什么位置,用一个简单的点(.)指定哪些网格单元格是空的。

这种布局方法的优点是,它可以很容易地将许多其他元素放置在我们想要的任何地方,这就是网格布局的强大之处。

结论

这些方法中的每一个都允许我们在容器中水平和垂直地居中一个div。place-selfmargin: auto选项很好,因为它们直接应用于居中的元素,而不是其容器。但是本文中介绍的所有方法都是高效的,并且可以很好地完成这项工作。在各种场景中,我们可能希望将元素置于中心,因此拥有一系列工具来实现该目标非常重要。

在演示示例中,我们只是使用了一个空的div,但是当然我们可以向div添加内容,居中仍然有效。而且这些居中技术同样适用于div以外的元素。

最后

有兴趣的可以看看原文,可以在线体验不同颜色格式是如何工作的。看完本文如果觉得有用,记得点个赞支持,收藏起来说不定哪天就用上啦~

专注前端开发,分享前端相关技术干货,公众号:南城大前端(ID: nanchengfe)