CSS中长度单位的使用

 在写css的时候最常用的长度单位是px(像素),经常看到的还有em,pt等等,其实css中的长度单位一共有8个,分别是px,em,pt,ex,pc,in,mm,cm。

  1、px:像素(Pixel),相对于设备的长度单位,像素是相对于显示器屏幕分辨率而言的。

  譬如,WONDOWS的用户所使用的分辨率一般是96像素/英寸。而MAC的用户所使用的分辨率一般是72像素/英寸。

  2、em:相对长度单位。相对于当前对象内文本的字体尺寸。

  如当前行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸。

  3、pt:点(Point),绝对长度单位。

  4、ex:相对长度单位。相对于字符“x”的高度。此高度通常为字体尺寸的一半。

  如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸。

  5、pc:派卡(Pica),绝对长度单位。相当于我国新四号铅字的尺寸。

  6、in:英寸(Inch),绝对长度单位。

  7、mm:毫米(Millimeter),绝对长度单位。

  8、cm:厘米(Centimeter),绝对长度单位。

  其中:1in = 2.54cm = 25.4 mm = 72pt = 6pc ;

  容器的大小我们经常用px做单位;字体大小(font-size)很多人用px做单位,其实用px做字体单位唯一的致命缺点就是在IE下无法用浏览器字体缩放的功能。

  但是,个人认为现在用px做字体单位在IE下无法用浏览器字体缩放的功能的缺点已经不再是那么重要了。因为新版本IE7,IE8都已经支持整个网页的缩放功能,包括火狐默认也是缩放整个网页,而不是缩放字体,没那么单纯的缩放字体大小还有什么重大的意义吗?按住Ctrl+滚动鼠标的中间的滚轮试试!IE进步了!

-----------------------------------------------------------------------------补充一下-------------------------------------------------

**  单位em的说明

em指字体高,任意浏览器的默认字体高都是16px。所以未经调整的浏览器都符合:1em=16px。那么12px=0.75em。但是em并不是固定的,它会继承父级元素的字体大小。你可能会在content这个div里把字体大小设为1.2em, 也就是12px。然后你又把选择器p的字体大小也设为1.2em,但如果p属于content的子级的话,p的字体大小就不是12px,而是1.2em= 1.2 * 12px=14.4px。这是因为content的字体大小被设为1.2em,这个em值继承其父级元素body的大小,也就是16px * 62.5% * 1.2=12px, p作为其子级,em则继承content的字体高,也就是12px。所以p1.2em就不再是12px,而是14.4px

**  单位pt的说明

在印刷排版中,point是一个绝对值,它等于1/72英寸,可以用尺子丈量的,物理的英寸。但是在csspt含义却并非如此。因为我们的显示器被分割为了一个个的像素,单个像素只能有一种颜色 (为了简化,这里暂不讨论次像素反锯齿技术),要在屏幕上显示,必须先把以 pt 为单位的长度转换为以像素为单位的长度,这个转换的媒介,就是 DPI (事实上,这里的所谓的 DPI,是操作系统和浏览器中使用的术语,即为 PPI, pixels per inch,和扫描仪、打印机、数码相机中的 DPI 是不同的概念)

例如,无论在哪个操作系统中,Firefox 浏览器默认的 DPI 都是 96,那么实际上 9pt = 9 * 1/72 * 96 = 12px

所以,虽然“DPI”中的“I”和“1pt 等于 1/72 inch”中的“inch”,都不代表物理上的英寸,但这两个单位互相之间是相等的,也就在相乘中约掉了。

那么,真实的物理长度怎么计算呢?请拿出一把尺子,丈量你的显示器的可见宽度 (我这里是 11.2992 英寸),除以横向分辨率 (我这里是 1024 像素),得到的就是每个像素的物理长度。

现在我们可以回答这样一个问题,网页上 9pt 的字体究竟占用了多宽的空间?答案是:  9 * 1/72 * 96 * 11.2992 / 1024 = 0.1324 英寸 = 0.3363 厘米。

**  ptpx

虽然pt是绝对单位,但是那只是针对输出设备而言的,在文字排版工具(wordabobe)中是非常有用的字体单位。不管显示器的分辨率是多少,打印在纸面上的结果是一样的。

但是网页主要为了屏幕显示,而不是为了打印等其他需要的。而px能够精确地表示元素在屏幕中的位置和大小。

当然。在dpi96的情况下,9pt=12px


你可能感兴趣的:(css,相对长度,绝对长度)