div层内容居中
来源:互联网 发布:命令提示符修复网络 编辑:程序博客网 时间:2024/05/16 10:00
有时候,为了网页设计的美观,需要把div+css设计的页面里的某些div层里的文字垂直居中,包括多行文字以及单行文字;方法有不少,但真正能实现而代码又简洁的介绍不多,flymorn就为大家介绍几种适用的div文字垂直居中的方法。
首先要知道css里vertical-align无效,W3C官方对vertical-align做了下面的解释: “ This property affects the vertical positioning inside a line box of the boxes generated by an inline-level element.”
实际上,一个Box中由很多行很多元素组成,vertical-align只作用于在同一行内的元素,它的垂直并不是相对于整个Box而言的。前面定义了一个60px的高度,但是这个Box中存在很多行,那段文本并不能对齐到中央。因此希望那段文本对齐中间,需要给它定义一个line-height的属性,让line-height为60px,作用于一行的vertical-align就可以工作了。
如果是单行文字想垂直居中,只要保证div高和行高保持一致,就可以了。
用下面的代码即可实现:
CSS代码: #div-a{ height:60px; line-height:60px; }
XHTML代码: <div id="div-a"> 这是一个div </div>
如果还想让div里的文字水平居中,加上“text-align:center;”即可;
代码如下:
CSS代码: #div-a{ text-align:center; height:60px; line-height:60px; }
XHTML代码: <div id="div-a"> 这是一个div</div>
说明:如果在父级元素定义TEXT-ALIGN:center;这个的意思就是在父级元素内的内容居中;对于IE这样设定就已经可以了。但在mozilla中不能居中。解决办法就是在子元素定义时候设定时再加上“MARGIN-RIGHT:auto; MARGIN-LEFT:auto;”。
但是,如果是多行文字,上面的垂直居中的方法就不行了,得用变通的方法实现;这里建议使用table方法,在table外面再套上相应的div,代码如下:
<table>
<tr>
<td style="vertical-align:middle;height:300px;background-color:red">
CSDN博客<br />这是一个div<br />
</td>
</tr>
</table>
多行文字居中还有另外一种方法: 多行内容居中,且容器高度可变,也很简单,给出一致的 padding-bottom 和 padding-top 就行: .
middle-demo-2{ padding-top: 24px; padding-bottom: 24px; }
优点:
1. 同时支持块级和内联极元素
2. 支持非文本内容
3. 支持所有浏览器
缺点: 容器不能固定高度(参考)
如何使图片在DIV中垂直居中,可以用背景的方法。如下:
body{ BACKGROUND:url(http://www---------------) #FFF no-repeat center; }
关键就是最后的center,这个参数定义图片的位置。还可以写成“top left”(左上角)或者"bottom right"等,也可以直接写数值"50 30"。
- div层内容居中
- div层中内容的居中
- div层页面居中
- div内容垂直居中
- div内容居中显示
- DIV内容垂直居中
- div内容垂直居中
- Div 内容垂直居中
- div内容垂直居中
- DIV内容垂直居中
- div内容居中
- div 内容居中
- 如何使DIV层居中
- 如何使DIV层居中
- div层相对屏幕居中
- 弹出居中的div层
- div内容水平居中、垂直居中
- div中的内容居中对齐
- sizeof的一个经典题
- java设计模式-中介者模式(Mediator)
- IOS可以拖动的UIButton
- 面试经典问答和回答思路
- C语言可变参数列表应用——多字符串复制和链接
- div层内容居中
- 实习日志(7):Flex的repeater组件
- Road Repairs(CF 240E)
- Linux下安装Apache
- 叁:列(壹)
- 理解Android系统的进程间通信原理(一)----RPC中的代理模式
- Makefile详解(自己觉得重新看一次学了好多东西,红色字)
- 定点小数补码一位乘(校正法)
- Geomagic多边形编辑