您现在的位置是:网站首页> 编程资料编程资料
css line-height属性的使用技巧CSS中的line-height行高属性学习教程深入理解CSS height属性设置元素的高度CSS中的line-height行高属性的使用技巧小结CSS中行高line-height属性的一些使用技巧css属性行高line-height的用法详解css height属性中的calc方法详解
2021-09-06
1042人已围观
简介 本文介绍下,css中的line-height属性的用法,通过实例学习css line-height属性的具体用法,感兴趣的朋友参考下
css中用于设置行高的属性,line-height属性。
第一,对CSS3的选择器和类似header、nav、footer等标签不兼容,在不使用插件和JS处理的情况下,从纯CSS的角度来切入,可以采用类名来做定义,这是常用的替代方案。
项目中,针对元素背景不支持颜色渐变的情况,折中的方案是给其一个最合适的背景色,这样使得背景色和文字颜色能有个基本的对比和区分,不至于影响用户的阅读和正常浏览。
例如:
header.sub-hd{
position:relative;
height:40px;
background-image:-moz-linear-gradient(top, #13b9fd, #0183c3);
background-image:-o-linear-gradient(top, #13b9fd, #0183c3);
background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#13b9fd),color-stop(1,#0183c3));
box-shadow:inset 0 1px 4px #6cd5ff;
-moz-box-shadow:inset 0 1px 4px #6cd5ff;
-webkit-box-shadow:inset 0 1px 4px #6cd5ff;
text-align:center;
font-size:15px;
background-color:#099ddf;/*opera mobile不支持渐变的折中方案*/
}
针对IE6不识别html5标签的方法
第二,我们经常使用line-height属性,定义行高,尤其是需要设置垂直居中的时候,常常让height属性与line-height属性相同。而且其是可以继承的,一篇文章的父标签定义了行高属性,其子段落元素就不需要再次进行声明。可是,也有例外的情况。比如在Opera Mobile浏览器,就必须要再次声明,才能生效。
例子:
1,html代码
测试标题在Opera Mobile下的宽高
2,CSS代码
从手机上看页面效果:不居中!
通过观察红色边框大小,知道内标签h2的呈现高度与实际呈现的line-height一致,都不是我们父div定义的数值。
然后,我们给h2加上line-height属性值,可以设置为line-height:inherit或者line-height:40px;
1,CSS代码:
查看效果,竟然没有变化,依然没有垂直居中。这是为什么呢?
莫非是浏览器自身默认的属性优先级高过了当前的属性优先级。
更改一下优先级:
再看,果然可以了。垂直居中了。
由此我们页可以印证另一种说法:对于一个空容器,写入内容容器被撑开有了高度宽度,但实际上根本不是文字撑开了div的高度,而是line-height属性。
CSS中起高度作用的主要是height以及line-height了吧!如果一个标签没有定义height属性(包括百分比高度),那么其最终表现的高度一定是由line-height起作用,即使是IE6下11像素左右默认高度bug也是如此。
至于内部的机理,看这里很形象的表述:
到底这个line-height行高怎么就产生了高度呢?在inline box模型中,有个line boxes,这玩意是看不见的,这个玩意的工作就是包裹每行文字。一行文字一个line boxes。例如“艾佛森退役”这5个字,如果它们在一行显示,你艾佛森再牛逼,对不起,只有一个line boxes罩着你;但“春哥纯爷们”这5个字,要是竖着写,一行一个,那真是够爷们,一个字罩着一个line boxes,于是总计五个line boxes。line boxes什么特性也没有,就高度。所以一个没有设置height属性的div的高度就是由一个一个line boxes的高度堆积而成的。
其实line boxes不是直接的生产者,属于中层干部,真正的活儿都是它的手下 – inline boxes干的,这些手下就是文字啦,图片啊,span之类的inline属性的标签啦。line boxes只是个考察汇报人员,考察它的手下谁的实际line-height值最高,谁最高,它就要谁的值,然后向上汇报,形成高度。
例如:
取手下line-height最高的值。
则line boxes的高度就是40像素了。
虽然所有浏览器都支持 line-height 属性。但是任何的版本的 Internet Explorer (包括 IE8)都不支持属性值 "inherit"。因此在实际中,我们最好还是用数值定义line-height。
在本例中即为
当然,还有一种折中的办法,可以将内容高度设为浏览器默认行高差不多的数值,其余不足的用padding补齐,这样在Opera mobile下,继承浏览器的21px默认行高,就不需要通过加important标记覆盖浏览器默认值了。同时,在其他标准浏览器我们为其子元素指定一个同样的行高,这样就能做到暂时兼容opera mobile 和其他所有标准的浏览器
浏览器默认行高各不相同,一般范围在16px~21px之间。
例子:
header.sub-hd{
position:relative;
/*height:40px;*/
height:21px;
padding:9px 0;
background-image:-moz-linear-gradient(top, #13b9fd, #0183c3);
background-image:-o-linear-gradient(top, #13b9fd, #0183c3);
background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#13b9fd),color-stop(1,#0183c3));
box-shadow:inset 0 1px 4px #6cd5ff;
-moz-box-shadow:inset 0 1px 4px #6cd5ff;
-webkit-box-shadow:inset 0 1px 4px #6cd5ff;
text-align:center;
font-size:15px;
background-color:#099ddf;/*opera mobile不支持渐变的折中方案*/
}
header .tit{
-webkit-box-sizing:border-box;
position:absolute;
left:50%;
width:150px;
/*height:39px;line-height:39px; */
line-height:21px;
margin-left:-75px;
color:#fff;
text-shadow:0 1px 0 #333;
font-weight:bold;
overflow:hidden;
font-size:18px;
}
当然这种办法并不是最佳的解决途径,只是权宜之计。最好还是采用上面的优先级设定,通用。
还是有问题!
先来温习一下line-height属性可能的值:
normal,默认。
number 数字,此数字会与当前的字体尺寸相乘来设置行间距。
length 设置固定的行间距。单位em,px,pt等等。
百分比% ,基于当前字体尺寸的百分比行间距。
inherit ,规定应该从父元素继承 line-height 属性的值。
line-heignt不能是负数,line-height 属性设置行间的距离(行高)。会影响行框的布局。在应用到一个块级元素时,它定义了该元素中基线之间的最小距离而不是最大距离。
line-height 与 font-size 的计算值之差(在 CSS 中成为“行间距”)分为两半,分别加到一个文本行内容的顶部和底部。可以包含这些内容的最小框就是行框。
原始数字值指定了一个缩放因子,后代元素会继承这个缩放因子而不是计算值。
行高指的是文本行的基线间的距离。而基线(Base line),指的是一行字横排时下沿的基础线,基线并不是汉字的下端沿,而是英文字母x的下 端沿,同时还有文字的顶线(Top line)、中线(Middle line)和底线(Bottom line),用以确定文字行的位置
行高与字体尺寸的差称为行距(leading)
使用行高代替高度避免haslayout:在某些情形下,line-height可以和height互换,因为实现的效果一样。都能撑开一个高度,然而这两个css属性有一个较隐蔽的差异,就是使用height会使标签haslayout,而使用line-height则不会。以前只有IE6的时候曾流行使用height清除浮动,就是利用了IE下height使haslayout的属性。但有时候,haslayout并不需要,反而要避免。
都喜欢给line-height带单位,但是在一些情况下会出现问题,看例子:
第一行
第二行
两行文字发生了重叠。
为什么带单位的line-height继承,有可能会发生重叠的现象呢?
如果line-height属性值有单位,那么继承的值则是换算后的一个具体的px级别的值;而如果属性值没有单位,则浏览器会直接继承这个“因子(数值)”,而非计算后的具体值,此时它的line-height会根据本身的font-size值重新计算得到新的line-height 值。
上例中的div的line-height为150%,由于默认情况的字体大小为16px,所以div的具体line-height值可换算为16px*150%=24px,由于pre的line-height会继承24px这个换算过后的具体值,此时pre又被重新定义了font-size:30px;字体大小超过了line-height的大小,于是发生重叠。其它单位原理一样。
因此建议,养成给line-height不带单位的习惯,如line-height:1.5;这种写法避免重叠。
在显示文章的box里,px的表示方法首先是要被淘汰的。因为文章里面的文字是有大有小的,使用px定值,由于继承性,无法实现根据文字大小自动调整间距,会出现大号文字重叠的现象。normal也是不行的,一般文章显示最好是650像素的宽度,1.5倍的行距较好。
一般浏览器的normal值在1~1.2之间,使用normal必然文字间距过小,阅读吃力。
百分值也有继承性,但是有个很搓的办法可以实现文字间距自动适应于文字的大小,那就是使用“*”通配符,例如:.article_box *{line-height:150%;}就不会出现文字重叠的情况了。
相关内容
- css属性行高line-height的用法详解CSS中的line-height行高属性学习教程深入理解CSS height属性设置元素的高度CSS中的line-height行高属性的使用技巧小结CSS中行高line-height属性的一些使用技巧css line-height属性的使用技巧css height属性中的calc方法详解
- 纯css写的评分鼠标移入的效果附图浅谈CSS3鼠标移入图片动态提示效果(transform)css3+伪元素实现鼠标移入时下划线向两边展开的效果纯CSS实现商品图片点击放大效果CSS实现鼠标移入时图片的放大效果及缓慢过渡效果的示例代码
- css样式去重写法缩减代码量CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS list-style修改列表属性控制li标签样式css选择器设置标签样式的实例代码浅谈html5标签css3的常用样式将html标签在浏览器居中显示的css样式CSS list-style属性控制li标签样式示例代码CSS实现鼠标悬停改变其他标签样式的示例代码
- css控制水平衡线hr标签样式去掉其阴影效果CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS表达式(expression)解决IE6 position:fixed无效问题CSS expression判断表达式设置input样式CSS expression在Chrome的问题优化浏览器渲染 避免CSS expressionsCSS中使用expression完美设置页面最小宽度(兼容ie)css expression使用概述及其优缺点介绍CSS行为expression轻松实现IE6无抖动固定定位CSS中使用expression表达式
- 几个特殊的CSS选择符使用介绍CSS中的属性选择符和结构化伪类详解CSS中的类和ID选择符CSS中的选择符实际使用指南简介CSS中的各种选择符css选择符类型详细介绍CSS 选择符的用法和实例详解如何编写高效的 CSS 选择符
- 非首位子元素选择器加号“+”的使用CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS实现限制字数功能当对象内文本溢出时显示省略标记纯CSS定制文本省略的方法大全CSS实现单行、多行文本溢出显示省略号的实现方法css实现文本溢出显示省略号用css截取字符实现文字自动截断隐藏溢出文本css多行文本溢出时出现省略号的示例
- 使用CSS3的背景渐变Text Gradient 创建文字颜色渐变CSS3下的渐变文字效果实现示例css 进度条的文字根据进度渐变的示例代码css3实现文字扫光渐变动画效果的示例CSS3文字背景色渐变过渡特效源码CSS实现文字高光水波渐变的动态效果实例一款纯css3实现的颜色渐变按钮的代码教程CSS 网页文字渐变效果css实现文字颜色渐变的三种方法