导语:元素居中对齐在很多场景看上去很和谐很漂亮。除此之外,对于前端开发面试者的基础也是很好的一个考察点。下面跟着作者的思路,一起来看下吧。

场景分析

  • 一个元素,它有可能有背景,那我要它的背景居中对齐
  • 一个元素,它还有可能有个父级元素,那我要它居中于其父级元素
  • 一个元素,它也有可能还带有一些子内容,我要让它的子内容居中

场景建模

根据场景分析提出的一些假设,我们试着去建立对应的模型,下面是分别根据上面的三个场景设计的相关模型。

  • 搞父子元素居中对齐

  • 搞元素背景居中对齐

  • 搞元素内容居中对齐

场景实现

相关说明

为了统一,这里我们定义一个400*400px的带着黑色边框粉红色身体的类名为.box的父容器,它有可能会有一个200*200px的带着原谅色身体的类名为.box-son的子容器。这里为了效果能够直观且明显,笔者故意把背景图片的原始大小处理成小于宿主像素的大小。好吧,我们开始吧!

背景居中

我们做这样一件事,在一个div容器中,我们通过background-image属性引入一张背景,之后我们期望这张引入的背景呢,它能够水平垂直居中于宿主元素。

这里介绍两个属性background-repeatbackground-position,如果你初中英语好的话,我想你也应该知道了,这里字面意思就是这个属性的意思。一个是设置背景图片怎么铺宿主元素(默认时铺满的)更美丽的,另一个是设置背景图片相对于宿主元素的的位置,你可以传像素、百分比、相关方向单词(top、bottom、left、right)给它。当其为百分比的时候,它的计算公式如下:

(container width - image width) * (position x%) = (x offset value)
(container height - image height) * (position y%) = (y offset value)

简言之,就是宿主元素的宽高减去图片宽高乘以相关百分比就是相对于宿主元素左上角那个原点的位置。

在背景图片不重复的情况下,你想让一张图片居中于宿主元素的方法,可以有background-postion: center centerbackground-postion: 50%, 50%,也可以简写成background-postion: center或者background-postion: 50%

所以,在楼上这些前提下,我们大致能够归出一个类,形如:

/** 这里以复杂写法的百分比为例, 分别代表距离宿主元素左上角的x和y轴的距离**/
.box-son {
background-repeat: no-repeat;
background-position: 50%, 50%;
}

文字内容居中

如果宿主元素的内容是文字之类的,我们期望它能够居中于宿主元素,这里用到两个属性,一个是text-align,一个是line-heighttext-algin:center可以使内容水平居中于宿主元素,将line-height设置成宿主元素相同的高度,便可让宿主元素垂直居中。

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example11

子元素居中于父元素

相关说明

这里解释下,父相子绝,这个是我阉割了“父级元素相对定位,子级元素绝对定位”这句话浓缩后的叫法。后面出现这个概念我就不过多再进行重复介绍了。

父相子绝 + margin: auto

父元素相对定位子元素绝对定位后,设置其top、right、bottom、left都为0,之后我们将其的margin设置为auto。这样子的话,父级元素与子级元素他们之间空出来的部分都会被这个margin均匀撑开。

.box-position {
position: relative;
} .box-example1 {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
margin: auto;
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example1

父相子绝 + 负值margin

父元素相对定位子元素绝对定位后,子元素设置top: 50%; left:50%;,这里的百分比参考值是相对于父元素的宽高,参考的点是父元素的左上角和子元素的左上角,所以我们需要矫正一下,减去子元素宽高的一半。这件事可以让子元素的margin代劳。

.box-position {
position: relative;
} .box-example2 {
position: absolute;
top: 50%;
left: 50%;
margin-left: -100px;
margin-top: -100px;
}

相关例子链接: https://ataola.github.io/show/zj/center-middle.html#example2

父相子绝 + 平移(translate)

在楼上那个例子的基础上,为了矫正子元素的偏移,我们其实还可以用css的平移属性。这个平移的百分比是相对于其本身的宽高的,所以是向反方向50%。

.box-position {
position: relative;
} .box-example3 {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example3

父子double相(不推荐,做着玩玩的)

一个不成熟的做法哈,父子都是相对定位也还是可以勉强居中的,硬算嘛,这里没有太大价值就不展开了。

.box-position {
position: relative;
} .box-example4 {
position: relative;
top: 90px;
left: 90px;
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example4

父子double相 + rem(不推荐,同楼上)

没有太大价值,略过。

相关例子链接: https://ataola.github.io/show/zj/center-middle.html#example5

父相子绝 + calc

calc这个css属性可以允许在声明css属性值时执行一些计算,回到我们之前的那个矫正偏移量的模型上,那么这里很容易想到子元素top、left属性设置成50%减去子元素一半的这样一个模型。

.box-position {
position: relative;
}
.box-example6 {
position: absolute;
top: calc(50% - 100px);
left: calc(50% - 100px);
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example6

新旧flex

flex布局,但凡一个正经点的初面都会遇到的,因为它好用也很常用,这里介绍两种,一种是新版的flex布局的写法,一种是旧版的flex布局的写法

flex布局你就把它看成是一条轴线,一条长得还挺夯实的轴线,在这条轴线上,我们想要放一个盒子,有很多种放法,具体的可以搜下阮一峰老师的教程这里不再赘述。一个化繁为简的想法哈,这个是跟琦瑞哥学到的,就是我们很多时候也不一定能记得住那么多属性,我们期望做这样一件事,就是把它化抽象为形象。我们可以用具体的方位去表达我们的想法,简言之就是封装成一个类库,然后用一些接地气的类名去控制flex布局。

有兴趣的童鞋可以看下我实现的一个低配版的css样式库:https://ataola.github.io/show/box/assets/taolaui/flex.css

新版flex的写法

在不改变轴方向的情况下,其父元素设置align-items: center;表示垂直居中,justify-content: center;表示水平居中。

父元素设置:

.flex {
display: flex;
} .flex-middle {
align-items: center;
} .flex-center {
justify-content: center;
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example7

旧版flex的写法

这里就是提及一下有这么种存在,读者用新版的写法就好。

.box-old {
display: -webkit-box;
-webkit-box-pack: center;
-webkit-box-align: center;
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example8

table布局

父元素设置display: table,子元素设置display:table-cell,在只有一个子元素的情况下它会尽可能撑满父元素,多个子元素的情况下水平均分。设置vertical-align: middle可以使得其内容垂直居中。

.box-table {
display: table;
} .box-son-table {
display: table-cell;
vertical-align: middle;
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example9

grid布局

前面我们提到的flex布局时轴布局是一维的,这里的grid网格布局时二维的是平面的。将其父元素设置成display:grid,然后子元素设置align-self: center;表示垂直居中,justify-self: center;表示水平居中。

.box-grid {
display: grid;
} .box-son-grid {
align-self: center;
justify-self: center;
}

相关例子链接:https://ataola.github.io/show/zj/center-middle.html#example10

最后

相关实现地址已开源:https://ataola.github.io/show/zj/center-middle.html,若有不足之处,供批评指正!

其他网页设计基础总结:https://ataola.github.io/show/

参考文献

https://developer.mozilla.org/zh-CN/docs/Web/CSS/background-position

https://developer.mozilla.org/zh-CN/docs/Web/CSS/background-repeat

https://developer.mozilla.org/zh-CN/docs/Web/CSS/calc


本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。

网页元素居中的n种方法的更多相关文章

  1. 使用CSS完成元素居中的七种方法

    在网页布局中元素水平居中比元素垂直居中要简单不少,同时实现水平居中和垂直居中往往是最难的.现在是响应式设计的时代,我们很难确切的知道元素的准确高度和宽度,所以一些方案不大适用.据我所知, 在CSS中至 ...

  2. CSS绝对定位元素居中的几种方法

    转载自-CSS居中绝对https://www.cnblogs.com/skura23/p/6530556.html 作者:PajamaCat 1,div宽度未知1 <body> <d ...

  3. 元素居中的两种方法,transform和margin

    1.transform :translate(-50%,-50%) <!DOCTYPE html> <html lang="en"> <head> ...

  4. jquery阻止元素冒泡的两种方法

    通常情况下,如果给父元素添加事件之后,子元素也会继承同样的事件,这个时候就要阻止子元素的这种行为,成为阻止冒泡,总结两种解决方法: html代码: <div id="parent&qu ...

  5. Knockout获取数组元素索引的2种方法,在MVC中实现

    原文:Knockout获取数组元素索引的2种方法,在MVC中实现 在遍历数组.集合的时候,通常要获取元素的索引,本篇体验使用Knockout获取索引的2种方法. 假设有这样的一个模型: namespa ...

  6. after及before伪元素及解决父元素塌陷的几种方法

    一.伪类和伪元素 CSS中伪类和伪元素有很多,也很好用!如果熟练使用的话可以解决很多问题 首先明白什么是伪类:伪类是基于当前元素的状态,而不是元素的id class等静态标志,它是动态变化的,它会在一 ...

  7. 【亲测显式等待】Selenium:元素等待的4种方法

    Selenium:元素等待的4种方法 1.使用Thread.sleep(),这是最笨的方法,但有时候也能用到而且很实用.   2.隐式等待,隐性等待是指当要查找元素,而这个元素没有马上出现时,告诉We ...

  8. js中如何删除某个元素下面的所有子元素?(两种方法)

    js中如何删除某个元素下面的所有子元素?(两种方法) 一.总结 方法一:通过元素的innerHTML属性 元素element.innerHTML=""; 方法二:通过元素的remo ...

  9. Qt中的布局浅析与弹簧的使用,以及Qt居中的两种方法

    1. 布局 为什么要布局: 布局之后窗口的排列是有序的 布局之后窗口的大小发生变化, 控件的大小也会对应变化 如果不对控件布局, 窗口显示出来之后有些控件的看不到的 布局是可以嵌套使用 常用的布局方式 ...

随机推荐

  1. 王艳 201771010127《面向对象程序设计(java)》第七周学习总结

    1.实验目的与要求 (1)进一步理解4个成员访问权限修饰符的用途: (2)掌握Object类的常用API用法: (3)掌握ArrayList类用法与常用API: (4)掌握枚举类使用方法: (5)结合 ...

  2. (STL初步)映射:map

    map就是从键(key)到值(value)的映射. 因为重载了[]运算符,map像是数组的”高级版“. 例如,map<string,int>month_name 表示:”月份名字到月份编号 ...

  3. Kd Tree算法详解

    kd树(k-dimensional树的简称),是一种分割k维数据空间的数据结构,主要应用于多维空间关键数据的近邻查找(Nearest Neighbor)和近似最近邻查找(Approximate Nea ...

  4. 【Java8新特性】Stream API有哪些中间操作?看完你也可以吊打面试官!!

    写在前面 在上一篇<[Java8新特性]面试官问我:Java8中创建Stream流有哪几种方式?>中,一名读者去面试被面试官暴虐!归根结底,那哥儿们还是对Java8的新特性不是很了解呀!那 ...

  5. OpenStack的Trove组件详解

    一:简介     一.背景 1. 对于公有云计算平台来说,只有计算.网络与存储这三大服务往往是不太够的,在目前互联网应用百花齐放的背景下,几乎所有应用都使用到数据库,而数据库承载的往往是应用最核心的数 ...

  6. (板子) 最小生成树 买礼物 luogu P1194

    luogu题目传送门! 懒得找最小生成树模板了,就把这题当板子吧. 最小生成树,就是指对于一张图,我们将图转换成一棵树,连通的,同时让所有的边尽可能的小(废话). 最小生成树一般都采用Kruskal算 ...

  7. NIO 的非阻塞式网络通信

    1.阻塞与非阻塞   ①  传统的 IO 流都是阻塞式的.也就是说,当一个线程调用 read() 或 write()时, 该线程被阻塞,直到有一些数据被读取或写入,该线程在此期间不能执行其他任务. 因 ...

  8. 关于Backus-Naur Form巴克斯诺尔范式和扩展巴克斯范式的知识点和相关词语中英文对照

    巴克斯诺尔范式的相关词语中英文对照和知识点 syntax 语法 强调的是编程语言的组形式,例如一个句子中会包含表达式.陈述还有各种单元等等 semantics 语义 强调的是这个编程语言的实际含义,例 ...

  9. 08 . Nginx状态码

    HTTP状态码 本篇文章主要介绍运维过程中经常遇到的状态码,并通过业界流行的Nginx进行模拟实现. 2XX状态码 2XX类型状态码表示一个HTTP请求成功,最典型的就是200 # 200状态码 # ...

  10. 添加对docker的监控

    一.环境:已安装docker机器ip:192.168.0.202 二.原理 使用docker的metrics-add参数,提供对docker运行参数的访问条件. 三.修改/etc/docker/dae ...