理解vertical-align或“如何竖向居中”<转>
在各种技术论坛里经常会有这样的问题提出,“我如何能将这个东西竖向居中?”这个问题通常会跟随着这样一句话,“我使用了 vertical-align:middle,但是不管用! ”
这个问题其实有三个层面的原因
- HTML布局通常都不是专门针对竖向呈现而设计的。这很自然,一般文字占宽会自动扩展,内容的高度是依据内容的多少和有效宽度而定。很显然,横向宽度和横向布局很容易实现;竖向高度和布局被动跟随横向布局适应。
vertical-align:middle没有按预期的设想起作用的原因通常是程序员没有理解其正确的用法,但…- … 这又是因为CSS规范(以我的观点)把它给弄拧巴了—依赖
vertical-align使用的场合的不同(vertical-align只对inline和inline-block依赖),它实际上会表现出两种完全不同的用法。
Table单元格中的vertical-align
当出现在Table单元格中时,vertical-align的效果会如大多数人的预期一样,它会跟(老的,不鼓励使用)的valign属性的作用一样。在现代浏览器里,下面的这三种写法的效果是一样的:
<td valign="middle"> <!-- 这是一种会逐渐被淘汰的用法 --> </td> <td style="vertical-align:middle"> ... </td> <div style="display:table-cell; vertical-align:middle"> ... </div>
在浏览器中,它们的现实效果是下面这样:
<td> 使用valign="middle" |
<td> 使用valign="bottom" |
<td> 使用vertical-align:middle |
<td> 使用vertical-align:bottom |
<div> 使用display:table-cell; vertical-align:middle<div> 使用display:table-cell; vertical-align:bottomvertical-align在inline元素上效果
然而,当vertical-align被应用的到inline元素上时,它的作用却是类似(老的,不鼓励使用)的valign属性对<img>的作用一样。在现代浏览器里,下面的这三种写法的效果是一样的:
<img align="middle" ...> <img style="vertical-align:middle" ...> <span style="display:inline-block; vertical-align:middle"> ... </span>
在浏览器中,它们的现实效果是下面这样:
在这个段落中,我放了两个图片—和
—作为例子。
在这个段落中,我放了两个图片—和
—作为例子。
在这个段落中,我用<span> display:inline-block
vertical-align:middle 和 display:inline-block
vertical-align:text-bottom 作为例子。
vertical-align在其它元素上的效果
技术上,某个CSS属性并不是在任何的HTML元素上都是生效。当一个新手将vertical-align属性应用到一个block元素(例如标准的<div>)上时,大多数浏览器会依照继承的原则,将所有它的inline子元素也应用这个属性。
那么,如何将一个元素竖向居中?
如果你在读这篇文章,你很可能对为什么你的写法不好用并不感兴趣。你感兴趣的很可能是如何能让它起作用。
方法一
下面的方法有两个(小)前提。如果你能做到这些前提,那么这个方法适用于你:
- 你需要把想要竖向居中的内容放到一个block元素中,并给这个想要居中的元素指定固定的高度。
- 绝对定位(absolutely-position)这个元素。(通常这样做是没问题的,因为你这个想要居中的元素的父元素仍然可以使用相对位置)。
如果你能接受上面的两个必要条件,那么,方法是这样的:
- 指定父元素为
position:relative或position:absolute。- 给子元素指定固定的高度。
- 给子元素设定
position:absolute以及top:50%,让子元素移动到父元素内部上下居中的位置。- 给子元素设定
margin-top:-yy,这里的 yy 的值是你的子元素的高度的一半,弥补居中时的偏差。
下面是CSS代码:
<style type="text/css"> #myoutercontainer { position:relative } #myinnercontainer { position:absolute; top:50%; height:10em; margin-top:-5em } </style>
下面是HTML代码:
<div id="myoutercontainer"> <div id="myinnercontainer"> <p>Hey look! I'm vertically centered!</p> <p>How sweet is this?!</p> </div> </div>
在浏览器中,上面的代码会产生如下的效果:
海,看看!我竖向居中了!
好厉害,不是吗?!
方法二
这个方法需要你满足下面的前提条件:
- 需要竖向居中的内容只有一行文字。
- 需要对父元素设定固定的高度。
如果你能接受上面的条件,那么,方法是这样:
- 将父元素的
line-height设置为你想要的高度。
下面是CSS代码的写法:
<style type="text/css"> #myoutercontainer2 { line-height:4em } </style>
下面是HTML代码的写法:
<p id="myoutercontainer2"> 嗨,我竖向居中了,耶! </p>
在浏览器中,上面的代码会产生如下的效果:
理解vertical-align或“如何竖向居中”<转>的更多相关文章
- 使用Flexbox实现CSS竖向居中
竖向居中需要一个父元素和一个子元素合作完成. <div class="flexbox-container"> <div>Blah blah</div& ...
- What is Vertical Align?
https://css-tricks.com/what-is-vertical-align/ ************************************************* CSS ...
- 通过vertical-align属性实现“竖向居中”显示
自学编程大概有大半年的时间了,从15年7月开始学习使用人数最多的JAVA,到后来喜欢上了前端,但由于之间在建筑设计院的工作加班颇为频繁,每天刨去工作,基本没有多少自己个人的时间,只能每天6,7点起床, ...
- 可滚动UIStackView 竖向居中 / 横向右对齐
重点: 在scroll view和stack view之间加一个UIView. 竖向居中Tutorial: https://stackoverflow.com/questions/50766400/c ...
- 关于Vertical Align的理解
1:vertical-align 翻译就是垂直-对齐... 2:关于line-height的点 2.1:如果一个标签没有定义height属性,那么其最终表现的高度一定是由line-height起作用. ...
- 浏览器兼容CSS代码:按钮文字垂直居中(input button text vertical align)
经过测试的浏览器:IE6, IE7, IE8, IE9, Firefox, Chrome, Safiri, Maxthon 按钮的HTML代码: <input id="btn_comm ...
- 三行代码CSS竖向居中
.element{ position:relative; top:50%; transform:translateY(-50%); } 这里无需设置高度或者父元素的position属性.(IE9可用) ...
- 前端知识点回顾之重点篇——CSS中vertical align属性
来源:https://www.cnblogs.com/shuiyi/p/5597187.html 行框的概念 红色(line-height)为行框的顶部和底部,绿色(font-size)为字体的高度, ...
- Vertical Center TextView . 竖直居中的UITextView
@interface VerticalCenterTextView : UITextView @end @implementation VerticalCenterTextView - (void) ...
随机推荐
- windows10 onenote 显示英文 怎么办?
转自:https://jingyan.baidu.com/article/fdffd1f85d064df3e98ca108.html 原因:首选输入法为英文. 方法:修改,调整首选为中文. 1.右下角 ...
- 转:RSA算法原理说明
转:http://www.joenchen.com/archives/979 RSA算法可以说在我们使用计算机的每一方面都在发挥着作用, EXE文件的签名算法用的是SHA1 + RSA. 我们每天登陆 ...
- [AngularJS] Angular 1.3 Anuglar hint
Read More: http://www.linkplugapp.com/a/953215 https://docs.google.com/document/d/1XXMvReO8-Awi1EZXA ...
- send返回值
http://blog.csdn.net/anghlq/article/details/5990513 在Unix系统下,如果send . recv . write在等待协议传送数据时 , socke ...
- 【转】linux下的单线程
传统的每个进程中只有一个线程在执行,称作单线程方法.MS-DOS是一种支持单用户进程和单线程的操作系统,UNIX支持多用户进程,但只支持每个进程一个线程,WINDOWS 2000(W2K).SOLAR ...
- OpenERP对象字段定义的详解
OpenERP对象支持的字段类型有,基础类型:char, text, boolean, integer, float, date, time, datetime, binary:复杂类型:select ...
- 17-spring学习-AOP初步实现
AOP是面向方面的编程,在实际开发中,AOP都会工作在业务层,因为业务层要调用数据层,而业务层也要完成所有辅助性的业务层操作. 范例:定义业务层操作接口: package com.Spring.Ser ...
- cocos2d-x 源代码分析 : EventDispatcher、EventListener、Event 源代码分析 (新触摸机制,新的NotificationCenter机制)
源代码版本号来自3.x,转载请注明 cocos2d-x 源代码分析总文件夹 http://blog.csdn.net/u011225840/article/details/31743129 1.继承结 ...
- jQuery ajax 流程全解析
实例解析java + jQuery + json工作过程(登录) 本文主要讲解在java环境下使用jQuery进行JSON数据传送的交互过程 参考根据作者的账务管理系统(个人版) 源码下载 讲解 一. ...
- JavaScript异常处理
http://www.yaosansi.com/post/747.html 异常处理概述 在代码的运行过程中,错误是不可避免的,总的来说,错误发生于两种情况:一是程序内部的逻辑或者语法错误, ...