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

CSS实现水平居中的几种方法有:

1.

  • 对于行内元素,可以使用 text-align: center;
一个例子。假设你有一个span元素,你想让它水平居中。你可以使用text-align的方法
<style>
  .container {
    height: 200px;
    background: lightgray;
    text-align: center;
  }

  .center {
    background: green;
    padding: 10px;
  }
style>

<div class="container">
  <span class="center">我是水平居中的spanspan>
div>
这样,你就可以实现水平居中的效果,只需要设置父元素的text-align为center。

CSS实现水平居中的几种方法_第1张图片

2.

  • 对于确定宽度块级元素
  • 可以使用 margin: 0 auto;
  • 或者使用绝对定位和 left: 50%; margin-left: - (宽度值/2);
  • 或者使用绝对定位和 top: 0; right: 0; bottom: 0; left: 0; margin: auto;
一个例子。假设你有一个div元素,你知道它的宽度是300px,你想让它水平居中。你可以使用margin的方法
<style>
  .container {
    height: 200px;
    background: lightgray;
  }

  .center {
    width: 300px;
    margin: 0 auto;
    background: green;
    padding: 10px;
  }
style>

<div class="container">
  <div class="center">我是水平居中的divdiv>
div>
这样,你就可以实现水平居中的效果,只需要设置div的宽度和左右margin为auto。

CSS实现水平居中的几种方法_第2张图片

3.

  • 对于未知宽度块级元素
  • 可以使用 display: table; margin: 0 auto;
  • 或者使用 display: inline-block; text-align: center;
  • 或者使用绝对定位和 left: 50%; transform: translateX(-50%);
  • 或者使用相对定位和 left: 50%; right: 50%;
  • 或者使用CSS3的flex布局和 align-self: center;
  • 或者 margin: auto;
  • 或者使用CSS3的fit-content和 margin: 0 auto;
一个例子。假设你有一个div元素,你想让它水平居中,但是你不知道它的宽度。你可以使用绝对定位和transform的方法,如下:
<style>
  .container {
    position: relative;
    height: 200px;
    background: lightgray;
  }

  .center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: green;
    padding: 10px;
  }
</style>

<div class="container">
  <div class="center">我是水平居中的div</div>
</div>
这样,你就可以实现水平居中的效果,而不需要知道div的宽度。

CSS实现水平居中的几种方法_第3张图片

你可能感兴趣的:(CSS,css,css3,html)