CSS居中完全解决方案_html/css_WEB-ITnose
程序员文章站
2024-01-17 23:19:58
...
上次面试面试官问到了,问了个定宽局中和不定宽局中,下来我把所有有关CSS居中都总结了一下
原文摘自我的前端博客,欢迎大家来访问
http://www.hacke2.cn
水平居中行内元素
把行内元素嵌套在一个DIV中,并且在DIV中设置以下样式
a{ text-align: center; }
块级元素
对于定宽的块级元素,我们要设置起margin-top,margin-right 为auto
.center{ margin: 0 auto; }
多个块级元素(inline-block)
多个块级元素,我们将其display设置为inline-block;然后将父级元素设置一下属性
div{ text-align: center; }
多个块级元素(flex)
设置需要水平居中的块状元素的父元素display为flex ,并且justify-content属性为center即可
body{ display: flex; justify-content: center; }垂直居中
单行 行内元素
将行内元素的height和line-height设置为一致即可
a{ height: 200px; line-height:200px; }
多行 行内元素
如果行内元素文字过多产生多行,则在父级元素设置display: table-cell;vertical-align:middle;
.container{ width: 300px; height: 300px; display: table-cell; vertical-align:middle; }
已知高度的块级元素
将块级元素设置绝对定位,top为50%,margin-top:-height/2
div{ height: 100px; position: absolute; top: 50%; margin-top: -50px; padding:0; }
未知高度的块级元素
使用CSS translate,将块级元素设置绝对定位,top为50%,transform: translateY(-50%);
div{ position: absolute; top: 50%; transform: translateY(-50%); padding:0; }水平垂直居中
已知高度、宽度的元素
将块级元素设置绝对定位,top为50%,left:50%;margin-top:-height/2;margin-left:-width/2
div{ width: 150px; height: 150px; position: absolute; top: 50%; left: 50%; margin-top: -75px; margin-left: -75px; }
已知高度、宽度的元素(flex)
给父级使用flex布局
div{ display: flex; justify-content:center; align-items: center; }
未知高度、宽度的元素
使用CSS translate
div{ position:absolute; top:50%; left:50%; -webkit-transform:translate(-50%,-50%); -moz-transform:translate(-50%,-50%); transform:translate(-50%,-50%); }
上一篇: 使用原会话_PHP
下一篇: jquery实现图片跟随鼠标移动
推荐阅读
-
my97datepicker 只能选1天_html/css_WEB-ITnose
-
网页元素在没有id/名称/时候怎么样取它的文本呢?_html/css_WEB-ITnose
-
CSS居中完全解决方案_html/css_WEB-ITnose
-
请教ie6上的css问题_html/css_WEB-ITnose
-
CSS+JS实现图片集展示(续)_html/css_WEB-ITnose
-
单行文本框怎样才能不回车自动提交?_html/css_WEB-ITnose
-
看好你的门-客户端传数据(10)-不安全的HTML禁用元素_html/css_WEB-ITnose
-
简单实现兼容各大浏览器的js复制内容到剪切板_html/css_WEB-ITnose
-
CSS:height: 100%失效原因,如何让它生效_html/css_WEB-ITnose
-
解决iframe无限嵌套问题。_html/css_WEB-ITnose