美文网首页
水平居中和垂直居中

水平居中和垂直居中

作者: 能吃饭也能吃苦1236 | 来源:发表于2018-04-29 21:32 被阅读0次
  • 水平居中设置--行内元素
text-align:center ;
/*如果被设置元素为文本、图片等行内元素时,水平居中是通过给父元素设置 text-align:center 来实现的。*/
  • 水平居中设置--定宽块级元素
  当被设置元素为 块状元素 时用 text-align:center 就不起作用了,这时也分两种情况:定宽块状元素和不定宽块状元素。
  定宽块状元素:块状元素的宽度width为固定值。
  满足定宽和块状两个条件的元素是可以通过设置“左右margin”值为“auto”来实现居中的。

  html代码:
  <body>
    <div>我是定宽块状元素,哈哈,我要水平居中显示。</div>
  </body>

  css代码:
  <style>
    div{
      border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/
      width:200px;/*定宽*/
      margin:20px auto;/* margin-left 与 margin-right 设置为 auto */
     }
  </style>
  • 水平居中设置--不定宽块状元素
方法一:加入 table 标签,利用table标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。
  第一步:为需要设置的居中的元素外面加入一个 table 标签 ( 包括 <tbody>、<tr>、<td> )。
  第二步:为这个 table 设置“左右 margin 居中”(这个和定宽块状元素的方法一样)。

  html代码:
  <div>
    <table>
      <tbody>
        <tr><td>
        <ul>
          <li>我是第一行文本</li>
          <li>我是第二行文本</li>
          <li>我是第三行文本</li>
        </ul>
        </td></tr>
      </tbody>
    </table>
  </div>
  css代码:
  <style>
    table{
      border:1px solid;
      margin:0 auto;
    }
  </style>
 
方法二:改变块级元素的 display 为 inline 类型(设置为 行内元素 显示),然后使用 text-align:center 来实现居中效果。如下例子:
  html代码:
  <body>
    <div class="container">
      <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
      </ul>
    </div>
  </body>
  css代码:
  <style>
    .container{
      text-align:center;
    }
    /* margin:0;padding:0(消除文本与div边框之间的间隙)*/
    .container ul{
      list-style:none;
      margin:0;
      padding:0;
      display:inline;
    }
    /* margin-right:8px(设置li文本之间的间隔)*/
    .container li{
      margin-right:8px;
     display:inline;
    }
  </style>

  方法三:通过给父元素设置 float,然后给父元素设置 position:relative 和 left:50%,子元素设置 position:relative 和 left: -50% 来实现水平居中。

  代码如下:
  <body>
    <div class="container">
      <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
      </ul>
    </div>
  </body>

  css代码:
  <style>
    .container{
      float:left;
      position:relative;
      left:50%
    }

    .container ul{
      list-style:none;
      margin:0;
      padding:0;
      position:relative;
      left:-50%;
    }
    
    .container li{
      float:left;
      display:inline;
      margin-right:8px;
    }
  </style>
  • 垂直居中--父元素高度确定的单行文本
父元素高度确定的单行文本的竖直居中的方法是通过设置父元素的 height 和 line-height 高度一致来实现的。
line-height 与 font-size 的计算值之差,在 CSS 中成为“行间距”。分为两半,分别加到一个文本行内容的顶部和底部。
这种文字行高与块高一致带来了一个弊端:当文字内容的长度大于块的宽时,就有内容脱离了块。

 如下代码:
 <div class="container">
   hi,imooc!
 </div>
 css代码:
 <style>
   .container{
     height:100px;
     line-height:100px;
     background:#999;
   }
 </style>
  • 隐性改变display类型
position : absolute ;
 float : left ;
 float:right;
只要html代码中出现以上两句之一,元素的display显示类型就会自动变为以 display:inline-block(块状元素)的方式显示,当然就可以设置元素的 width 和 height 了,且默认宽度不占满父元素。

相关文章

  • css水平居中和水平垂直居中

    水平居中和水平垂直居中demo

  • 常用的居中方法

    本文将介绍的居中方法有 ,水平居中,垂直居中和水平垂直居中。 一水平居中 二水平垂直居中

  • css 居中

    居中有水平居中和垂直居中。 水平居中+垂直居中 flex法 position法 就是计算呗~ 参考 CSS各种居中...

  • 居中对齐

    行内元素居中[#hang]垂直居中[#hc]水平居中[#hs] 块级元素居中[#kuai]垂直居中[#kc]水平居...

  • 水平居中与垂直居中

    水平居中和垂直居中可以说是在开发中经常遇到的问题,网上搜索水平居中和垂直居中的方法有很多,有的方法并不是很好,所以...

  • 实现元素水平居中的五种方法

    概述 我们平时看到的居中效果主要分为三大类,水平居中,垂直居中和水平垂直居中,在这里总结以下元素水平居中的方法。 ...

  • 水平居中和垂直居中

    水平居中设置--行内元素 水平居中设置--定宽块级元素 水平居中设置--不定宽块状元素 垂直居中--父元素高度确定...

  • 水平居中和垂直居中

    #水平居中 1.1.已知宽度块元素宽度 : 1.2.文本内容居中: 1.3.通过表格: 1.4.已知宽度,通过设置...

  • 水平居中和垂直居中

    假设有如下html结构 一、实现item在header内水平居中1、item定宽度 2、item不定宽度ps: m...

  • 水平居中和垂直居中

    水平居中 1、行内元素 父元素: 此方法父元素有没有宽度都ok 2、块级元素 需要居中的元素设置宽度 设置css ...

网友评论

      本文标题:水平居中和垂直居中

      本文链接:https://www.haomeiwen.com/subject/wcvnlftx.html