CSS中的长度单位的应用介绍

本篇文章给大家带来的内容是关于css中的长度单位的应用介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

CSS中有很多属性可以接受长度值,比如: width, height, margin, padding, border-width, font-size, text-shadow。因为使用场景多,因此CSS也提供了许多长度单位。有的是日常生活中使用的单位,比如:厘米(cm)和英寸(in);有的是印刷行业使用的单位,比如:point(pt)和pica(pc);有的是专门为CSS发明的单位,比如:px。

使用场景

那么这些属性和单位怎么配合使用呢?特定的属性需要使用特定的单位吗?其实并非如此,单位和属性无关,同一个属性任何单位都适用,何时使用何种单位是没有限制的,如果属性接受以px为单位的值(比如:margin: 5px),那么它也可以接受英寸或厘米(margin: 1.2in; margin: 0.5cm)为单位的值,反之亦然。

单位虽然和属性无关,但是和输出的媒介有一定关系,比如输出到是屏幕还是纸张。在屏幕上显示和在纸张上面打印推荐使用的单位是不一样的。下表给出了推荐的使用方法:

输出媒介 推荐 偶尔使用 不推荐

屏幕em, px, %expt, cm, mm, in, pc打印em, cm, mm, in, pt, pc, %px, ex

除了和输出媒介的关系,这些单位可以从长度值的计算方式区分为绝对单位和相对单位。

立即学习“前端免费学习笔记(深入)”;

绝对单位

绝对单位(px,cm, mm,in,Q,pt和pc)意味着以此为单位的长度值与其代表的物理长度相等,比如width: 1cm即与现实世界中的1cm长度相等,也意味着绝对单位在所有的媒介上的显示效果是一致的。但这是理想情况,受显示器和不同浏览器CSS实现的差异,在很多设备上绝对单位显示的并不精确。因为px和in的关系为1in=96px, 在低分辨率设备上,1px为1像素(pixel,也是px名称的由来)长度,而低分辨率的屏幕上1px往往大于1/96in,所以从px计算得到的其他绝对单位值都不准确。而在高分辨率设备上(如现在的高清屏和打印机)绝对单位显示得更精确。由于以上原因,绝对单位更多的是在打印时使用。

曾经,CSS要求在计算机屏幕上正确显示绝对单位。但是由于大部分厂商并不能实现这一要求,所以CSS在2011年放弃了这一要求。目前,绝对单位仅在打印和高分辨率设备上正常工作。CSS没有明确定义“高分辨率”的含义。但是,由于目前低端打印机的每英寸点数为300 dpi,而高端屏幕的每英寸点数为200 dpi,因此所谓的“高分辨率”可能介于两者之间。。

下面贴出绝对单位直接的换算公式:

1in = 2.54cm = 25.4mm = 72pt = 6pc = 96px

登录后复制

px

作为CSS中最常用的单位,关于px还是有必要多说两句的。px的特点可以归纳如下:

在低分辨率设备上,1px = 1像素;

在高分辨率设备上,1px = 1/96in,1px不一定等于1像素(比如4.7英寸的iphone上 1px=2像素);

对于图片显示,1px = 1图片像素,比如:一个600×400分辨率的照片的的CSS宽高即为600px和400px(在4.7英寸iphone上要用1200×800个像素点显示);

相对单位

相对单位意味着长度值是根据其他长度计算得出的。相对单位又可以分为基于字体(font based)和基于视窗(viewport based)的:

Font Based

em, ex

首先说说em和ex,em代表元素的当前字体大小,如果元素的font-size为2cm,那么1em即表示2cm。em可以用于控制尺寸,比如margin: 1em; text-indent:1.5em,此时这些尺寸和元素字体大小相关,因此在大屏幕上(字体尺寸较大)和小屏幕上(字体尺寸较小)会等比缩放,因此em可以用于响应式的设计。如果em直接用于font-size属性,如font-size: 2em,则em表示为父元素字体的大小。

ex很少被使用,ex表现的大小与字体的x-height相关。x-height大致等于字体中小写字母(例如a,c,m或o)的高度。相同font-size的不同字体的x-height可能会有很大的差别,所以使用ex产生的效果存在很大的不确定性。

rem

CSS在2013年创造出了一个新的单位rem,rem表示的是根元素(html元素的)字体大小,在每个元素里面em都可能不一样,但是rem都是一致的。因为这一特性,rem现在被更广泛的应用于响应式设计。

ch

ch用的表较少,是CSS3中新加入的单位,表示当前字体中的 “0” (零、unicode 字符 U+0030) 的宽度。

Viewport Based

vw,wh,vmin,vmax

都是CSS3中新加入的单位。vw,vh可以根据视窗大小调整字体大小。vw是视窗的1/100的宽度,而vh是视窗1/100的高度。此外还有vmin,它指的是vw以及vh间较小的那个,与之相对的还有vmax。这些单位在目前大部分浏览器上都有支持。

以上就是CSS中的长度单位的应用介绍的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2889126.html

(0)
上一篇 2025年3月10日 21:18:20
下一篇 2025年3月8日 17:46:22

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css3核心知识点的小结(代码示例)

    本篇文章给大家带来的内容是关于css3核心知识点的小结(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 css3前缀(浏览器兼容) 根据了解,css3属性大部分支持ie10,部分支持ie9,少部分支持ie8 //…

    编程技术 2025年3月10日
    200
  • @keyframes是什么

    @keyframes是css的一种规则,可以用来定义css动画的一个周期的行为,创建简单的动画。 css @keyframes 作用:通过 @keyframes 规则,您能够创建动画。 说明: 创建动画的原理是,将一套 CSS 样式逐渐变化…

    2025年3月10日
    200
  • nav-up属性如何使用

    nav-up属性设置或检索对象的导航方向,有四个属性值可以设置:auto(浏览器决定导航到哪个元素), id(规定被导航元素的id,target-name (规定被导航的目标框架),inherit(规定应从父元素继承 nav-up 属性的值…

    2025年3月10日
    200
  • border属性怎么用

    border属性的使用方法:首先创建一个HTML示例文件;然后在body中输入p标签;最后通过给p元素设置“border:2px solid red;”来设置边框样式即可。 本文操作环境:Windows7系统、HTML5&&…

    2025年3月10日
    200
  • CSS文件中如何引入另一个CSS文件?(代码示例)

    我们可以使用@import规则来实现css文件中如何引入另一个css文件,@import规则可以在主html文件或主css文件中导入多个css文件,本篇文章就来给大家具体介绍一下,希望对大家有所帮助。 @import规则 首先我们来了解一下…

    2025年3月10日
    200
  • @charset规则怎么用

    在css中@charset规则用于指定样式表中使用的字符编码;它必须是样式表中的第一个元素,如果定义了多个@charset规则,则只会使用第一个。下面本篇文章就来带大家认识一下@charset规则,希望对大家有所帮助。 CSS @chars…

    2025年3月10日
    200
  • CSS的+(加号)选择器怎么用

    在css中“+”符号选择器用于选择紧跟在指定元素之后但不在特定元素内部的元素。下面本篇文章就来具体介绍一下,希望对大家有所帮助。 “+”符号选择器 在CSS中“+”符号选择器被称为相邻兄弟选择器,用于选取在同一父元素下的,紧跟指定元素之后的…

    2025年3月10日
    200
  • clear属性怎么用

    clear属性设置元素左侧或右侧的元素不浮动,可用于实现浮动的清除,解决浮动布局带来的一些问题。 CSS clear属性 作用:clear属性可以设置浮动元素左右两侧的元素不浮动。 语法: clear:none | left | right…

    2025年3月10日
    200
  • css all属性怎么用?

    all属性是用来将除了 unicode-bidi 和 direction外的所有属性重置为其初始值或从父元素那继承的值。 CSS all属性 all属性实际上是所有CSS属性的缩写,表示,所有的CSS属性都怎样怎样;但是,不包括unicod…

    2025年3月10日
    200
  • css align-content属性怎么用

    align-content属性是用来设置自由盒内部各个项目在垂直方向排列方式。 CSS align-content属性 作用:align-content属性是用来设置自由盒内部各个项目在垂直方向排列方式;它修改了flex-wrap属性的行为…

    2025年3月10日
    200

发表回复

登录后才能评论