> 웹 프론트엔드 > HTML 튜토리얼 > CSS垂直居中方法总结_html/css_WEB-ITnose

CSS垂直居中方法总结_html/css_WEB-ITnose

WBOY
풀어 주다: 2016-06-24 11:48:05
원래의
1059명이 탐색했습니다.

一、把容器当作表格单元

<div class="middle-demo1">    <button>按钮</button></div>
로그인 후 복사
.middle-demo1{ display: table-cell; height: 100px; //可以动态改变高度,这里只是演示 vertical-align: middle; border: 1px solid #666; }
로그인 후 복사

浏览器支持情况:
http://caniuse.com/#search=table-cell

二、固定高度的元素垂直居中

<div class="middle-demo2">    <div class="g-box"></div></div>
로그인 후 복사
.middle-demo2{ position: relative; width: 200px; height: 200px; border: 1px solid #666; }.g-box{ position: absolute; top: 50%; width: 100px; height: 100px; margin-top: -50px; background-color: deepskyblue; }或者.g-box{ position: absolute; top: 50%; width: 100px; height: 100px; -webkit-transform: translateY(-50px); -moz-transform: translateY(-50px); -ms-transform: translateY(-50px); -o-transform: translateY(-50px); transform: translateY(-50px); background-color: deepskyblue; }
로그인 후 복사

说明:要垂直居中的元素(g-box)必须是固定高度(js动态计算设置除外)。
transform的浏览器支持情况http://caniuse.com/#search=transform

三、固定高度的元素垂直居中

<div class="middle-demo3">    <div class="g-box2"></div>    <div class="g-box3"></div></div>
로그인 후 복사

g-box3是需要垂直居中的元素

.middel-demo3{ position: relative; width: 200px; height: 200px; border: 1px solid #666; }.g-box2{ height: 50%; margin-bottom: -50px; }.g-box3{ height: 100px; background-color: deepskyblue; }
로그인 후 복사

说明: 要垂直居中的元素(g-box3)必须是固定高度。

四、不定高元素垂直居中

<div class="middle-demo4">    <div class="g-box4"></div></div>
로그인 후 복사
.middle-demo4{ position: relative; width: 200px; height: 200px; border: 1px solid #666; }.g-box4{ position: absolute; top: 0; bottom: 0; margin-top: auto; margin-bottom: auto; width: 100px; height: 100px; background-color: deepskyblue; }
로그인 후 복사

说明: 要垂直居中的元素(g-box4)可以不固定高度,浏览器支持情况IE8+,其他浏览器支持较好

五、单行文本垂直居中

<div class="middle-demo5">    <span>单行文本</span></div>
로그인 후 복사
.middle-demo5{ height: 100px; line-height: 100px; border: 1px solid #666; }
로그인 후 복사

说明: 对内部的块状元素无效

六、容器定高或者不定高,多行文本垂直居中

<div class="middle-demo6">    <p>单行文本</p>    <p>多行文本</p></div>
로그인 후 복사
.middle-demo6{ display: table-cell; vertical-align: middle; height: 200px; //容器可以不定高,这里只是演示 border: 1px solid #666; }
로그인 후 복사

七、vertical-align实现行内元素垂直居中

<div class="middle-demo7">    <span class="g-fix"></span>    <button class="g-box7">行内元素</button></div>
로그인 후 복사
.middle-demo7{ position: relative; width: 200px; height: 200px; border: 1px solid #666; }.g-fix{ display: inline-block; width:0; height: 100%; vertical-align: middle; }
로그인 후 복사

说明: 浏览器支持情况http://caniuse.com/#search=inline-block

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿