CSS布局奇技淫巧:各种居中

2017-08-23 无双 前端开发

作者:无双

链接:www.cnblogs.com/2050/p/3392803.html

居中是我们使用css来布局时常遇到的情况。使用css来进行居中时,有时一个属性就能搞定,有时则需要一定的技巧才能兼容到所有浏览器,本文就居中的一些常用方法做个简单的介绍。

注:本文所讲方法除了特别说明外,都是兼容IE6+、谷歌、火狐等主流浏览器的。

先来说几种简单的、人畜无害的居中方法

1. 把margin设为auto

具体来说就是把要居中的元素的margin-left和margin-right都设为auto,此方法只能进行水平的居中,且对浮动元素或绝对定位元素无效。

2、使用 text-align:center

这个没什么好说的,只能对图片,按钮,文字等行内元素(display为inline或inline-block等)进行水平居中。但要说明的是在IE6、7这两个奇葩的浏览器中,它是能对任何元素进行水平居中的。

3、使用line-height让单行的文字垂直居中

把文字的line-height设为文字父容器的高度,适用于只有一行文字的情况。

4、使用表格

如果你使用的是表格的话,那完全不用为各种居中问题而烦恼了,只要用到 td(也可能会用到 th)元素的 align=”center” 以及 valign=”middle” 这两个属性就可以完美的处理它里面内容的水平和垂直居中问题了,而且表格默认的就会对它里面的内容进行垂直居中。如果想在css中控制表格内容的居中,垂直居中可以使用 vertical-align:middle,至于水平居中,貌似css中是没有相对应的属性的,但是在IE6、7中我们可以使用text-align:center来对表格里的元素进行水平居中,IE8+以及谷歌、火狐等浏览器的text-align:center只对行内元素起作用,对块状元素无效。

在ie6、7中可以通过css的text-algin来控制表格内容的水平方向的对齐,无论内容是行内元素还是块状元素都有效。

但在ie8+以及chrome、firefox等浏览器中的text-align:center对块状元素无效,只能用表格自有的align属性。

5、使用display:table-cell来居中

对于那些不是表格的元素,我们可以通过display:table-cell 来把它模拟成一个表格单元格,这样就可以利用表格那很方便的居中特性了。例如:

但是,这种方法只能在IE8+、谷歌、火狐等浏览器上使用,IE6、IE7都无效。

那面所说的都是很基础的方法,自然不能称之为奇淫巧计,下面就来说一些需要使用一些技巧的居中方法。

6、使用绝对定位来进行居中

此法只适用于那些我们已经知道它们的宽度或高度的元素。

绝对定位进行居中的原理是通过把这个绝对定位元素的left或top的属性设为50%,这个时候元素并不是居中的,而是比居中的位置向右或向左偏了这个元素宽度或高度的一半的距离,所以需要使用一个负的margin-left或margin-top的值来把它拉回到居中的位置,这个负的margin值就取元素宽度或高度的一半。

运行效果:

如果只想实现一个方向的居中,则可以只使用left , margin-left 来实现水平居中,使用top , margin-top来实现垂直居中。

7、另一种使用绝对定位来居中的方法

此法同样只适用于那些我们已经知道它们的宽度或高度的元素,并且遗憾的是它只支持IE9+,谷歌,火狐等符合w3c标准的现代浏览器。

下面用一段代码来了解这种方法:

运行效果:

这里如果不定义元素的宽和高的话,那么他的宽就会由left,right的值来决定,高会由top,bottom的值来决定,所以必须要设置元素的高和宽。同时如果改变left,right , top , bottom的值还能让元素向某个方向偏移,大家可以自己去尝试。

8、使用浮动配合相对定位来进行水平居中

此方法也是关于浮动元素怎么水平居中的解决方法,并且我们不需要知道需要居中的元素的宽度。

浮动居中的原理是:把浮动元素相对定位到父元素宽度50%的地方,但这个时候元素还不是居中的,而是比居中的那个位置多出了自身一半的宽度,这时就需要他里面的子元素再用一个相对定位,把那多出的自身一半的宽度拉回来,而因为相对定位正是相对于自身来定位的,所以自身一半的宽度只要把left 或 right 设为50%就可以得到了,因而不用知道自身的实际宽度是多少。

这种使用浮动配合相对定位来居中的方法,优点是不用知道要居中的元素的宽度,即使这个宽度是不断变化的也行;缺点是需要一个多余的元素来包裹要居中的元素。

看下代码:

运行效果:

9、利用font-size来实现垂直居中

如果父元素高度是已知的,要把它里面的子元素进行水平垂直居中,则可以使用这种方法,且子元素的宽度或高度都不必知道。

该方法只对IE6和IE7有效。

该方法的要点是给父元素设一个合适的font-size的值,这个值的取值为该父元素的高度除以1.14得到的值,并且子元素必须 是一个inline或inline-block元素,需要加上vertical-align:middle属性。

至于为什么是除以1.14而不是其他的数,还真没有人知道,你只需要记住1.14这个数就行了。

在方法5中说过在IE8+、火狐谷歌等现在浏览器中可以用display:table-cell来进行居中,而这里的font-size的方法则适用于IE6和IE7,所以把这两种方法结合起来就能兼容所有浏览器了:

         

上面的例子中因为要居中的元素是一个块状元素,所以我们还需要把他变成行内元素,如果要居中的元素是图片等行内元素,则可以省略此步。

另外,如果 vertical-align:middle 是写在父元素中而不是子元素中,这样也是可以的,只不过计算font-size时使用的  1.14 这个 数值要变成大约 1.5 这个值。

以上就是一些常见的居中方法了,如有疏漏或错误之处,敬请指正!


●本文编号469,以后想阅读这篇文章直接输入469即可

●输入m获取文章目录

推荐↓↓↓

Web开发

更多推荐18个技术类微信公众号

涵盖:程序人生、算法与数据结构、黑客技术与网络安全、大数据技术、前端开发、Java、Python、Web开发、安卓开发、iOS开发、C/C++、.NET、Linux、数据库、运维等。

阅读原文

阅读 4986

18投诉

精选留言

写留言

  •  13
    青峰
    transform:translate (-50%,-50%);

    2017年8月23日

  •  7
    王一衡
    居中必然还是要有display:flex。以flex布局来实现居中的

    2017年8月23日

  •  2
    对对我这个新手来说涨了点知识

    2017年8月23日

  •  2
    劉凯里?
    flex大法好

    2017年8月23日

  •  1
    初心不负
    flex弹性布局的第一句话就是你还在采用div+浮动+定位来布局?真是Out了 flex全帮你解决了

    2017年8月27日

  •  1
    追梦的girl
    对伪元素垂直居中,水平居中兼容各个浏览器

    2017年8月24日

  •  1
    Sloan
    居中我只服flex

    2017年8月23日

  •  
    柯昭阳
    前端大全公众号早就发了,你现在才发

    2017年8月23日

  •  
    Ateoa
    最后一种 你这给要居中的元素多套了一个层级。 其实有不增加层级的方法的。可以通过transform 直接往回平移元素的50%

    2017年8月23日

  •  
    梁伟文?
    ie6

    2017年8月23日

以上留言由公众号筛选后显示

了解留言功能详情

转载于:https://www.cnblogs.com/liuhao-web/p/8715419.html

CSS布局奇技淫巧:各种居中相关推荐

  1. css布局中的居中问题

    css布局中的居中问题 作者:阿捷 2004-7-5 14:35:49 #sample{ HEIGHT:240px;WIDTH:400px; BACKGROUND: url(http://www.w3 ...

  2. 典型的DIV+CSS布局——左中右版式

    [效果] [HTML] <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Defa ...

  3. div+css 布局下兼容IE6 IE7 FF常见问题

    div+css 布局下兼容IE6 IE7 FF常见问题 收藏 所有浏览器 通用 (市面上主要用到的IE6 IE7 FF) height: 100px; IE6 专用 _height: 100px; I ...

  4. 典型的DIV+CSS布局(左中右)

    典型的DIV+CSS布局--固定宽度且居中的版式中,运用的是浮动属性:这个实例,则运用了绝对定位属性. 1.在#container中设置"position:relative;",其 ...

  5. 最强大的 CSS 布局 —— Grid 布局

    Grid 布局是什么? Grid 布局即网格布局,是一种新的 CSS 布局模型,比较擅长将一个页面划分为几个主要区域,以及定义这些区域的大小.位置.层次等关系.号称是最强大的的 CSS 布局方案,是目 ...

  6. css布局:为什么margin-right不起效果,如何居中显示。

    css布局:为什么margin-right不起效果 ,以及如何居中显示. 不清楚这个问题其实是没有弄明白网页水平布局的一个小原理 假设这里有一个div,在这个div盒子里面有一个小的div盒子 (这里 ...

  7. HTML变列自适应布局三行,div自适应居中_典型的DIV CSS三行二列居中高度自适应布局...

    摘要 腾兴网为您分享:典型的DIV CSS三行二列居中高度自适应布局,弈玩游戏,携程,悟空单车,我和你等软件知识,以及驾考精灵,指尖遥控,广告拦截,浙江学习网,360主题桌面,平板电脑qq,咖啡厅室内 ...

  8. CSS布局:设置图片在DIV中上下左右居中(水平和垂直都居中)

    CSS布局实例,这个例子相信很实用,让一个图片在Div容器中上下.左右都居中,也就是水平和垂直都居中,有用吧,平时遇到的机率挺高的,下面结合CSS和HTML来实现这个演示,请参见代码: <sty ...

  9. CSS布局之-水平垂直居中

    对一个元素水平垂直居中,在我们的工作中是会经常遇到的,也是CSS布局中很重要的一部分,本文就来讲讲CSS水平垂直居中的一些方法. 另外,文中的css都是用less书写的,如果看不懂less,可以把我给 ...

最新文章

  1. 【Linux】一步一步学Linux——Centos7.5安装图解(08)
  2. 防止抓取html代码,网页中用html代码注释的内容会被抓取吗
  3. vue.js表格赋值_vue.js input框之间赋值方法
  4. Git 操作总结整合篇
  5. python3.5 pip安装_用python3.5 pip安装Numpy
  6. 【报告分享】2021人才资本趋势报告:重塑时代-BOSS直聘.pdf(附下载链接)
  7. java中有效关键字_java中有效的关键字
  8. mysql高级管理-note
  9. 硬盘坏了怎么恢复数据,需要哪些设备
  10. Java实现过滤敏感词汇
  11. cdr转换成html格式,如何将CDR高版本转换成低版本?CDRX7文件转换成X4教程
  12. 用c++随机生成10小学生算术题的课设
  13. css 动画 (transition animation)
  14. 六级通关笔记--词汇1
  15. Yuga Labs 收购 CryptoPunks 的始末
  16. PR(precision recall curve)曲线是什么?PR曲线如何绘制?为什么Precision和Recall是矛盾体、此消彼长?为什么提出F1指标?
  17. 华为手机怎么使用读卡器_手机nfc功能怎么打开(华为手机nfc功能使用步骤)
  18. WinForm(八)窗体,窗体
  19. math.h中常用的函数(C语言)
  20. 当代人工智能复习2022

热门文章

  1. 阿里云 fatal: Authentication failed 退出码 128
  2. poj 2151 Check the difficulty of problems
  3. [原创 - 尚学堂科技 - 马士兵老师]
  4. Skype通讯协议分析
  5. Android平台Qt开发入门教程
  6. Linux 开发板4G转WiFi热点 手机连接热点上网(一 思路)
  7. abb外部轴零位校准_RobotStudio软件:机器人自定义行走轴配置与仿真
  8. c# spire.xls 设置文字为微软雅黑_Excel工作薄常规样式设置,WorkBook.Styles
  9. 针对《等保2.0》要求的云上最佳实践——网络安全篇
  10. 云原生数据湖分析DLA 2020年年度总结