2种CSS居中布局实例 - 极悦
首页 课程 师资 教程 报名

2种CSS居中布局实例

  • 2021-04-01 17:18:27
  • 1002次 极悦

CSS是Web开发中不可或缺的一部分,随着Web技术的不断革新,CSS也变得更加强大。比如在Web布局中,现代CSS特性就可以更好的帮助我们快速实现如等高布局,水平垂直居中,经典的圣杯布局、宽高比例、页脚保持在底部等效果。CSS布局一直是CSS中非常重要的内容,本文我们就来介绍CSS布局中的2种CSS居中布局

一、水平居中

1.先来看最常用的一种方法,利用margin属性设置外边距,当要居中当元素是display:block时可以用这种方法。

<div class="container">

    <div class="content"></div>

  </div>

  <style>

    .content {

      width: 200px;

      height: 200px;

      background-color: #000;

      margin: 0 auto;

    }

  </style>

2.使用text-align,将元素当成文字直接居中。当要居中元素是inline或者是inline-block时可以在元素的父容器上使用。

<div class="container">

    <span class="content">文字内容</span>

  </div>

  <style>

    .container {

      text-align: center;

    }

  </style>

<div class="container">

    <a href="#" class="content">链接</a>

    <a href="#" class="content">链接</a>

    <a href="#" class="content">链接</a>

  </div>

  <style>

    .container {

      text-align: center;

    }

    .content {

      display: inline-block;

    }

  </style>

3.利用定位来居中元素。绝对定位元素可以通过这种方式来居中,让定位的元素据左边50%父容器的距离,然后再让向左移动本身50%的距离。

<div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      position: relative;

    }

    .content {

      position: absolute;

      width: 200px;

      height: 200px;

      background-color: #000;

      left: 50%;

      transform: translateX(-50%);

    }

  </style>

4.使用flex布局来居中。  

 <div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      display: flex;

      justify-content: center;

    }

    .content {

      width: 200px;

      height: 200px;

      background-color: #000;

    }

  </style>

5.使用grid布局来居中,但是只为实现单个元素居中不推荐这种写法 

 <div class="container">

    <div></div>

    <div class="content"></div>

    <div></div>

  </div>

  <style>

    .container {

      display: grid;

      grid-template-columns: auto 200px auto;

      grid-template-rows: 200px;

    }

    

    .content {

      background-color: #f40;

    }

  </style>

6.使用grid布局的第二种居中方法,类似于flex

<div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      display: grid;

      justify-content: center;

      grid-template-columns: 200px;

      grid-template-rows: 200px;

    }

  </style>

二、垂直居中

1.利用定位来实现,和水平居中的原理一致  

<div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      height: 640px;

      background-color: gray;

      position: relative;

    }

    .content {

      position: absolute;

      top: 50%;

      transform: translateY(-50%);

      width: 200px;

      height: 200px;

      background-color: #fff;

    }

  </style>

2.同时利用定位和外边距实现,让子元素的top和bottom的值保持相同,然后设置margin: auto;

  <div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      height: 640px;

      background-color: gray;

      position: relative;

    }

    .content {

      width: 200px;

      height: 200px;

      background-color: #fff;

      position: absolute;

      top: 0;

      bottom: 0;

      margin: auto 0;

    }

  </style>

3.使用flex布局来进行垂直居中 

 <div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      height: 640px;

      background-color: gray;

      display: flex;

      flex-direction: column;

      justify-content: center;

    }

    

    .content {

      width: 200px;

      height: 200px;

      background-color: #fff;

    }

  </style>

4.使用grid布局来进行垂直居中  

<div class="container">

    <div class="content"></div>

  </div>

  <style>

    .container {

      height: 640px;

      background-color: gray;

      display: grid;

      grid-template-columns: 200px;

      grid-template-rows: 200px;

      align-content: center;

    }

    .content {

      width: 200px;

      height: 200px;

      background-color: #fff;

    }

  </style>

5.使用line-height对文字进行居中  

<div class="container">

    500

  </div>

  <style>

    .container {

      height: 640px;

      background-color: gray;

      line-height: 640px;

    }

  </style>


2种CSS居中布局就是以上的内容,针对CSS水平居中和垂直居中的布局,文中都给出了多种方法,我们可以根据实际情况采用最适合的方法来完成页面的CSS布局设计。在本站的CSS教程中,除了介绍CSS布局之外,对CSS控制页面的各种属性的方法都有详细的介绍,学习起来都很方便。

 

选你想看

你适合学Java吗?4大专业测评方法

代码逻辑 吸收能力 技术学习能力 综合素质

先测评确定适合在学习

在线申请免费测试名额
价值1998元实验班免费学
姓名
手机
提交