line-height与vertical-align
css世界读书笔记:
内联元素与流
块级元素负责结构,内联元素接管内容
x元素的下边缘就是我们的基线baseline
x-height就是x的高度
vertical-align:middle是x中点位置,所以那个不是严格的中间对齐
ex单位是一个x的高度
利用那个ex单位可以做不受字体和字号影响的内联元素的垂直居中对齐效果
z<i class="icon-arrow"></i>
.icon-arrow {
display: inline-block;
width: 20px;
height: 1ex;
background: url(/images/5/arrow.png) no-repeat center;
}
line-height
非替代元素的纯内联元素,其可视高度完全由line-height决定,替代元素则不行。
行距 = line-height - font-size
半行距就是行距/2,但是没有小数表达,所以,如果标注的是文字上边距,则向下取整,如果是文字下边距,向上取整。因为据大多数的文体在内容区域是都是偏下的。
单行垂直居中 也是近似
不需要设置height只用line-height就可以
.line-height{
line-height: 50px;
font-size: 12px;
margin-top: 16px;
}
多行文本垂直居中
<style>
.box{
width: 280px;
line-height: 120px;
background-color: #f0f3f9;
margin: auto;
}
.content{
display: inline-block;
line-height: 20px;
margin: 0 20px;
vertical-align: middle;
}
</style>
<div class="box">
<div class="content">基于行高实现的多行文字垂直居中效果,需要vertical-align属性帮助。</div>
</div>
line-height的默认值,在个浏览器默认值不一样需要重制。最好是1.5的设置。
body{
line-height: 1.5;
}
input, button {
line-height: inherit;
}
内联元素line-height的最大值特性。
内联元素,自身有一个内联盒子,只用有内联盒子,就会有行框盒子,每个行框盒子前面都有一个宽度是0的具有该元素的字体和行高属性的看不见的幽灵空白节点
vertical-align
分4类:
- 线类:baseline(默认)/ top / middle/ bottom
- 文本类:text-top/text-bottom
- 上标下标类: sub/super
- 数值百分比类: 20px/2em/20%
在图文混排的页面中,内联元素默认都是沿着字母x的下边缘对齐的。对于图片等替换元素,往往使用本身的下边缘作为基线。我们可以通过数值或者百分比来调整位置。
兼容性好,支持ie67。可以精准的控制元素的垂直对齐位置。
HTML:
<p>请选择<i class="icon-arrow"></i></p>
<p>请选择<i class="icon-arrow valign-1"></i></p>
<p>请选择<i class="icon-arrow valign-2"></i></p>
CSS:
.icon-arrow {
display: inline-block;
width: 20px; height: 20px;
background: url(arrow.png);
}
.valign-1 {
vertical-align: middle;
}
.valign-2 {
vertical-align: -5px;
}
vertical-align的作用前提
只能应用到内联元素以及display值为table-cell的元素。(display是inline,inline-block,inline-table或者tabel-cell的元素上,默认span,strong,em等内联元素,img,botton,input等替代元素,非html规范的自定义标签元素,以及td 单元格,都是支持vertical-align属性,其他的块级元素则不支持,float和position会破坏)
vartical-align属性的默认值baseline在文本之类的内联元素那里就是字符x的下边缘,对于替换元素则是替换元素的下边缘,但是,如果是inline-block元素,规则要复杂le:一个inline-block元素,如果里面没有内联元素,或者overflow不是visible,则该元素的基线就是margin底边缘,否则其基线就是元素里面最后一行内联元素的基线。
利用上面的原理20px图标实践。
<div class="box">
<h4>1. 空标签后面跟随文本</h4>
<p><i class="icon icon-delete"></i>删除</p>
<h4>2. 标签里面有“删除”文本</h4>
<p><i class="icon icon-delete">删除</i>随便什么文字</p>
<h4>3. 字号变大</h4>
<p class="large">
<i class="icon icon-delete"></i>删除
</p>
<p class="large">
<i class="icon icon-delete">删除</i>随便什么文字
</p>
</div>
.icon {
display: inline-block;
width: 20px;
height: 20px;
white-space: nowrap;//不换行
letter-spacing: -1em; //
text-indent: -999em; //缩进 文字隐藏
}
.icon:before {
content: '\3000';//始终有内容,不让margin为下边距
}
top与bottom属性
top就是垂直上边缘对齐
- 内联元素:元素底部和当前行框盒子的顶部对齐
- table-cell元素:元素底padding边缘和表格行的顶部对齐
middle是近似垂直居中
text-top与text-bottom
对于内联元素,如果大家遇到不太友好理解的现象,请一定要意识到,有一个“幽灵空白节点”以及无处不在的vertical-align属性。
line-height与vertical-align的更多相关文章
- What is Vertical Align?
https://css-tricks.com/what-is-vertical-align/ ************************************************* CSS ...
- 浏览器兼容CSS代码:按钮文字垂直居中(input button text vertical align)
经过测试的浏览器:IE6, IE7, IE8, IE9, Firefox, Chrome, Safiri, Maxthon 按钮的HTML代码: <input id="btn_comm ...
- 关于Vertical Align的理解
1:vertical-align 翻译就是垂直-对齐... 2:关于line-height的点 2.1:如果一个标签没有定义height属性,那么其最终表现的高度一定是由line-height起作用. ...
- How to Take Control of Your Line Height in Outlook.com
Reference to: http://www.emailonacid.com/blog/details/C13/line_height_and_outlook.com
- 深入了解css的行高Line Height属性
什么是行间距? 古时候我们使用印刷机来出来文字.印刷出来的每个字,都位于独立的一个块中. 行间距,即传说中控制两行文字垂直距离的东东.在CSS中,line-height被用来控制行与行之间垂直距离. ...
- 前端知识点回顾之重点篇——CSS中vertical align属性
来源:https://www.cnblogs.com/shuiyi/p/5597187.html 行框的概念 红色(line-height)为行框的顶部和底部,绿色(font-size)为字体的高度, ...
- div仿checkbox表单样式美化及功能
div仿checkbox表单样式美化及功能(checkbox的样式不好看)素材在底部: 效果图: window.css .bj { position: absolute; top: 0; left: ...
- CSS布局设置
一 盒模型 盒模型 在CSS中,"box model"这一术语是用来设计和布局时使用,然后在网页中基本上都会显示一些方方正正的盒子.我们称为这种盒子叫盒模型. 盒模型有两种:标准模 ...
- 原生 JS 实现移动端 Touch 滑动反弹
什么是 Touch滑动?就是类似于 PC端的滚动事件,但是在移动端是没有滚动事件的,所以就要用到 Touch事件结合 js去实现,效果如下: 1. 准备工作 什么是移动端的 Touch事件?在移动端 ...
- height与line-height
1.网页的所有元素可以分为块元素和行元素.一行文字所在的一个逻辑区域是行元素,其他的元素就都是块元素line-height只针对行元素,height针对其他所有元素 2. width,height对于 ...
随机推荐
- 【BZOJ2730】[HNOI2012] 矿场搭建(找割点)
点此看题面 大致题意: 一张无向图,要求你在去掉任意一个节点之后,剩余的每个节点都能到达一个救援出口,问至少需要几个救援出口. 第一步:\(Tarjan\)求割点 首先,我们要跑一遍\(Tarjan\ ...
- 访问虚拟机中web服务的
经常发现假如我们想弄一点小玩意或跑一些小demo,总是要不断的在自己的工作本本上搭建不同的运行环境,久而久之,本本上充斥着各种软件,速度下降了,同时管理也非常的不方便.于是想到用虚拟机来搭建运行环境, ...
- cuda流测试=basic_single_stream
cuda流测试 /* * Copyright 1993-2010 NVIDIA Corporation. All rights reserved. * * NVIDIA Corporation and ...
- CUDA实现数组倒序
数组倒序,将在主机上初始化的数组传输到设备上,然后用CUDA并行倒序,此时在全局内存上操作,再将结果返回到主机并验证. #include <stdio.h> #include <as ...
- Oracle分页抽数存储过程
--outTotal是需要返回的总数,v_loginUserId是传入的登录人ID,抽取他的客户,v_CurrPage是传入的第几页,v_pageSize传入的每页数据条数. ) FROM tb_cu ...
- 线程池是什么?Java四种线程池的使用介绍
使用线程池的好处有很多,比如节省系统资源的开销,节省创建和销毁线程的时间等,当我们需要处理的任务较多时,就可以使用线程池,可能还有很多用户不知道Java线程池如何使用?下面小编给大家分享Java四种线 ...
- DevOps - 监控告警 - Zabbix
官网3.4版本中文文档 Zabbix documentation in Chinese [Zabbix Documentation 3.4] https://www.zabbix.com/docume ...
- 初识redis-cluster
安装redis [root@localhost ~]# cd /datas/soft/ [root@localhost soft]# ll redis-.tar.gz // 已经下载的最新版 -rwx ...
- Java中的接口和抽象类(转)
在面向对象的概念中,我们知道所有的对象都是通过类来描述的,但是并不是所有的类都是用来描绘对象的,如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类. 抽象类往往用来表征我们在对问题 ...
- [USACO]Bovine Genomics
Description 给定两个字符串集合A,B,均包含N个字符串,长度均为M,求一个最短的区间[l,r],使得不存在字符串\(a\in A,b\in B,\)且\(a[l,r]=b[l,r]\) , ...