几种常见的居中方式总结

长路漫漫
初学前端,说的不对望大家指点出来。放下你的砖头。

在页面布局中我们经常遇到元素居中问题:

  • 水平居中
  • 垂直居中
  • 水平垂直居中

水平居中

  • inline/inline-block + text-align
  1. 概况:对子元素设置display:inline/inline-block,对父级元素设置text-align: center;
  2. 详解:text-align概念:
    CSS属性定义行内内容(例如文字)如何相对它的块父元素对齐。text-align
    并不控制块元素自己的对齐,只控制它的行内内容的对齐。
    这里说明使用这种方法实现居中必须具备几点:
  • 父元素是块元素
  • 子元素是行内元素 常见的行内元素方法:display:inline/ inline-block
inline/inline-block + text-align
效果
  • 绝对定位
  1. 已知元素的宽度和高度
    当我们已知子元素的宽度以及高度的时候就可以使用负margin方法将元素居中;
    说明:这里使用父级元素position: relative子元素position:absolute
    原因是我们要使用绝对定位;使子元素的left值为父元素的50%;即 left:50%
    这样结果子元素的左侧就在父元素的距离50%的位置;

left:50%效果

这样其实并不是我们想要的效果,我们需要子元素整体居中,这时候就需要使用margin将元素放置到正确的位置;我们将子元素的margin设为-width/2;成了!
效果

负margin
  1. 未知子元素的宽高;
    原理都是一样的,只不过这一次我们不知道元素的宽度以及高度;那么就不能使用负margin;这时候css3一个方法:transform:translate() 就可以排上用场;
    首先了解一下概念:
  • CSS transform 属性允许你修改CSS视觉格式模型的坐标空间。使用它,元素可以被转换(translate)、旋转(rotate)、缩放(scale)、倾斜(skew).
  • CSS transform 属性 , 只对 block 级元素生效!
  • 这里我们使用translateX() 指定元素向X方向平移;
    那么这不就和负margin一个道理么,搞起!
transform
效果
  • table-cell
    将元素设置为display:table-cell mdn上是这样介绍table-cell的;

table-cell

这是什么意思;赶紧看看td的文档;这里我发现 td可以使用 text-align;vertical-align 属性;赶紧试试!

table-cell
效果
  • flexbox
    先放上资源:
  1. 阮一峰Flex布局
  2. mdn
    就是我们常说的flex布局了;移动端布局的拯救者;
    让我们来试试!
flex
效果
  • grid 布局
    笔者还没看过文档;看了之后这段补上,献上兼容性;
grid
暂时就能想到这几种方法;肯定还有别的方法。欢迎大家补充;-_-

下面的内容就从简了,基本原理都一样;

垂直居中

  • vertical-align :middle
    注意必须在父元素中指定line-height否则vertical-align不起作用;
vertical-align
效果
  • 固定宽高垂直居中
负margin
效果
  • 未知宽高 transform
transform
效果
  • table-cell
table-cell
效果
  • flex
flex
效果

水平垂直居中

  • table-cell + text-align + vertical-align
    父级元素table-cell
  • block + 负margin / transform
  1. 定宽定高元素 负margin
负margin
效果
  1. 未知宽高 transform
    通过使用css3属性对元素进行变换
transform
效果
  • flex
    使用flexbox对元素进行居中
flexbox
效果
奉上部分练习代码

github

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336