居中那点事
最近碰到一些居中的问题需要处理,这里整理下碰到的问题以及一些解决的方案
文本水平居中
text-align:center;
可以知道,让一个元素水平居中可以使内容是inline或inline-block 非文本场景下,其实padding也可以实现相同效果。这个可以根据内容自适应,不然这样一来外层容器宽度就不固定了。
文本垂直居中
文本垂直居中 单行的时候
line-height: 30px;height: 30px;
如果是多行,那么可以考虑这样子
padding: 30px 0;
这样上下间距一样了,多行无压力
图片居中
这里分几个场景 1 容器比较大,且容器和图片是固定了宽高的,那么用上面的思路很容易解决,内联+line-height或内联+padding
//css.wrap0 { height: 300px; width: 100%; text-align: center; } .c0{ line-height: 300px; display: inline-block;}
//dom<div class="wrap0"> <div class="c0">我好</div></div>
2 容器比较大,但容器和图片宽高是不固定的,那么图片需要如何做自适应处理呢 水平方向上,依然还是使用内联元素文本居中方式就可以实现。 垂直方向上,其实可以想想如果是文本是否还有其他垂直居中方式,vertical-align,让行内元素居中对齐。考虑到这个其实还是会有些问题,vertical-align是多个元素的对齐方式,那么或许可以考虑让另一个元素隐藏起来就好。
//css .wrap1 { height: 100%; width: 100%; position: fixed; text-align: center; } .c1 { height: 100px; width: 100px; background-color: gray; display: inline-block; vertical-align: middle; } .c2 { height: 100%; background-color: green; display: inline-block; vertical-align: middle; width: 0; }
//dom<div class="wrap1"> <div class="c1"></div> <div class="c2"></div></div>
3 容器比较小,而内容比较大,如何来做居中处理呢 首先来看看水平方向上如何处理 默认内容放置在容器中,内容和容器左边是对齐的,那么理论上是内层容器需要向左移动,才能实现对齐。现在的问题是需要移动多少呢
//考虑到方向position = (width[容器] - width[内容])/2
其实就是他们宽度之差的1/2,那么剩下的问题是怎么做到移动这么多? 常见的跟位置相关的样式有 top|left|right|bottom, margin, position,且 left和 margin是基于父元素的,那么如果内容设置了 left为50%,那么其实 width[容器]/2的值就出来了,而如果要实现 width[内容]/2,只需要在内容外嵌套一个元素,这个元素和内容宽高一致,那么设置内容 margin-left为50%,就可以实现了 width[内容]/2,考虑到公式是负值的,所以 margin-left应为50% 上面说的有些绕,可以直接看代码
.wrap1 { height: 100px; width: 200px; margin: 0 auto; text-align: center; border: 1px solid red; position: relative; } .wrap2 { height: 100px; width: 300px; margin: 0 auto; text-align: center; border: 2px solid blue; position: absolute; left: 50%; } .c1 { width: inherit; height: inherit; background-color: gray; margin-left:-50%; }
<div class="wrap1"> <div class="wrap2"> <div class="c1"></div> </div></div>
这里留一个坑,如果c1元素是inline-block样式,会发生什么呢
同时,如果想在垂直方向上来实现这个效果,要这么做呢。 很容易想到上面那种做法,可以动手试下看看。 实际上是不行的,margin-top的值是基于父元素的宽度来计算的,而不是基于高度。所以。。。。 我们也可以通过一些特殊的方式去改变计算方式。比如让margin根据父元素的高度去计算 所以我们只需要在上面的wrap1样式中添加如下代码即可。
-webkit-writing-mode: vertical-rl; /* for browsers of webkit engine */ writing-mode: tb-rl; /* for ie */
如果不采用这种样式,也可以使用js结合的方式去计算margin的值
多一点延伸的
其实提到按比例去计算位置,css3里面可以使用translate来配合使用,dom结构会更简洁,可悲的是万恶的ie8. 还是看看代码,先看看容器比内容大的场景:
.wrap1 { width: 200px; height: 300px; margin: 300px auto; position: relative; border: 1px solid red; } .c1 { width: 100px; height: 200px; position: absolute; top: 50%; left: 50%; background-color: gray; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
<div class="wrap1"> <div class="c1"></div></div>
上述代码在内容比容器大的时候照样适用
参考
- css writing mode
- margin系列之百分比

theroottaginanhtmldocumentis.servesasthetop-levellementThateNcapsulatesAllotherContent,确保properdocumentstrumentstrumentsureandbrowserparserparsing。

文章解释说,HTML标签是用于定义元素的语法标记,而元素是完整的单位,包括标签和内容。他们一起工作以构建网页。查拉克计数:159

本文讨论了Lt; Head&gt; &&lt;身体&gt; HTML中的标签,它们对用户体验的影响以及SEO的影响。正确的结构增强了网站功能和搜索引擎优化。

本文讨论了HTML标签,和和关注其语义与表现用途及其对SEO和可访问性的影响之间的差异。

文章讨论了在HTML中指定字符,重点介绍了UTF-8。主要问题:确保正确显示文本,防止乱七八糟的字符,并增强SEO和可访问性。

本文讨论了用于构建和造型Web内容的各种HTML格式标签,强调了它们对文本外观的影响以及语义标签对可访问性和SEO的重要性。

本文讨论了HTML的“ ID”和“类”属性之间的差异,重点是它们的独特性,目的,CSS语法和特异性。它解释了它们的使用如何影响网页样式和功能,并为


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SublimeText3汉化版
中文版,非常好用

WebStorm Mac版
好用的JavaScript开发工具

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)