彻底掌握CSS中的percentage百分比值使用

所属分类: 网页制作 / CSS 阅读数: 1273
收藏 0 赞 0 分享

百分比旨在相对于父元素的相同属性的大小。
如果用来设置字体,则相对的就是父元素的字体大小。
大多数浏览器中<html> 和<body> 标签中的默认字体尺寸是100%.

CSS Code复制内容到剪贴板
  1. html {font-size: 100%;}   
  2. body {font-size: 100%;}   
  3. 100% = 1em = 16px = 12pt  

如果用来设置宽和高等非字体尺寸,则以百分比为单位的长度值是基于具有相同属性的父元素的长度值。

CSS Code复制内容到剪贴板
  1. <!DOCTYPE html>   
  2. <html>   
  3. <head>   
  4.   <meta charset="utf-8">   
  5.   <title>JS Bin</title>   
  6.   <style type="text/css">   
  7.   div.parent {   
  8.     margin:150px;   
  9.     width200px;   
  10.     height200px;   
  11.     border1px solid blue;   
  12.   }   
  13.   div.child {   
  14.     width: 50%;   
  15.     height: 50%;   
  16.     border1px dashed black;   
  17.   }   
  18.   </style>   
  19. </head>   
  20. <body>   
  21.   <div class="parent">   
  22.     <div class="child"></div>   
  23.   </div>   
  24. </body>   
  25. </html>  

再啰嗦一点关于父元素的问题:何为父元素,相对定位(relative),绝对定位(absolute),浮动(float),固定(fixed)中如何找寻父元素?
由于HTML是树形结构,标签套标签,一般情况下的父子关系很明朗。

XML/HTML Code复制内容到剪贴板
  1. <div class="parent">  
  2.     <div class="child"></div>  
  3. </div>  

1.相对定位元素,它的父元素符合标签嵌套。
2.绝对定位元素,它的父元素是离它最近的定位元素(绝对定位,相对定位,固定,但不包括浮动)或者视窗尺寸(没找到定位元素时)。
3.浮动元素,它的父元素也符合标签嵌套。
4.固定元素(特殊的绝对定位),它的父元素是视窗(浏览器默认用来展示内容的区域的尺寸,不是html 或body 的尺寸)。
注意一下绝对定位就行了,其他的相对简单。

CSS Code复制内容到剪贴板
  1. <!DOCTYPE html>   
  2. <html>   
  3. <head>   
  4.   <meta charset="utf-8">   
  5.   <title>JS Bin</title>   
  6.   <style type="text/css">   
  7.     html {   
  8.         width:1000px;   
  9.     }   
  10.     body {   
  11.         width:800px;   
  12.     }   
  13.     #box {   
  14.         width:50%;   
  15.         height:300px;   
  16.         positionabsolute;   
  17.         margin-left200px;   
  18.         border1px solid red;   
  19.     }   
  20.     #can {   
  21.         position:absolute;   
  22.         top:100px;   
  23.         left:100px;   
  24.         width:50%;   
  25.         height:50%;   
  26.         border:1px solid black;   
  27.     }   
  28.   </style>    
  29. </head>     
  30. <body>   
  31.     <div id="box">   
  32.         <div id="can"></div>   
  33.     </div>   
  34.        
  35. </body>     
  36. </html>  

201666113109667.png (800×318)

box 宽度为视窗的一半,can 的宽高是 box 的宽高的一半。
将 can 设置为 position: fixed; 则其父元素将不再是 box 而是浏览器视窗。
201666113144599.png (800×338)

can 的宽高是视窗宽高的一半。
浮动元素的父元素跟普通元素的父元素是一样的。

CSS Code复制内容到剪贴板
  1. <!DOCTYPE html>   
  2. <html>   
  3. <head>   
  4.   <meta charset="utf-8">   
  5.   <title>JS Bin</title>   
  6.   <style type="text/css">   
  7.     html {   
  8.         width:1000px;   
  9.     }   
  10.     body {   
  11.         width:800px;   
  12.     }   
  13.     #box {   
  14.         width:50%;   
  15.         height:300px;   
  16.         positionabsolute;   
  17.         margin-left200px;   
  18.         border1px solid red;   
  19.     }   
  20.     #can {   
  21.         float:left;   
  22.         width:50%;   
  23.         height:50%;   
  24.         border:1px solid black;   
  25.     }   
  26.   </style>    
  27. </head>     
  28. <body>   
  29.     <div id="box">   
  30.         <div id="can"></div>   
  31.     </div>   
  32.        
  33. </body>     
  34. </html>  

201666113210234.png (800×276)

注意: padding、 margin 如果设置了百分比,上,下,左,右 用的都是父元素宽度 的值为标准去计算。

percentage转px
Example 1: Margins

CSS Code复制内容到剪贴板
  1. <div style="width: 20px">   
  2. <div id="temp1" style="margin-top: 50%">Test top</div>   
  3. <div id="temp2" style="margin-right: 25%">Test rightright</div>   
  4. <div id="temp3" style="margin-bottom: 75%">Test bottombottom</div>   
  5. <div id="temp4" style="margin-left: 100%">Test left</div>   
  6. </div>  

得到的offset如下:

CSS Code复制内容到剪贴板
  1. temp1.marginTop = 20px * 50% = 10px;   
  2. temp2.marginRight = 20px * 25% = 5px;   
  3. temp3.marginBottom = 20px * 75% = 15px;   
  4. temp4.marginLeft = 20px * 100% = 20px;  

然后,我又测试了padding,原以为padding的值会根据应用了该属性的相关元素来计算,但让我惊讶的是,padding也是根据应用该属性的父元素的宽来计算的,跟margin表现一致。(再插一句:当按百分比设定一个元素的宽度时,它是相对于父容器的宽度计算的,元素竖向的百分比设定也是相对于容器的宽度,而不是高度。)
但有一个坑,上面都是对于未定位元素。好奇的我又很好奇,对于非静态定位元素的top, right, bottom, 和left的百分比值又怎么计算呢?
Example 2: Positioned Elements

CSS Code复制内容到剪贴板
  1. <div style="height: 100px; width: 50px">   
  2. <div id="temp1" style="position: relative; top: 50%">Test top</div>   
  3. <div id="temp2" style="position: relative; right: 25%">Test rightright</div>   
  4. <div id="temp3" style="position: relative; bottom: 75%">Test bottombottom</div>   
  5. <div id="temp4" style="position: relative; left: 100%">Test left</div>   
  6. </div>  

得到的offset如下:

CSS Code复制内容到剪贴板
  1. temp1.top = 100px * 50% = 50px;   
  2. temp2.rightright = 100px * 25% = 25px;   
  3. temp3.bottombottom = 100px * 75% = 75px;   
  4. temp4.left = 100px * 100% = 100px;  

对于定位元素,这些值也是相对于父元素的,但与非定位元素不同的是,它们是相对于父元素的高而不是宽。
when the parent element does not have a height, then percentage values are processed as auto instead
虽然有点困惑,但只需要记住:对于margin和padding,百分比按照父元素的宽计算,对于定位元素,则按照父元素的高计算。
文章的最后,推荐一个网站:http://www.css3.com,上面有很多关于CSS问题的资源。

更多精彩内容其他人还在看

Opera中国的WEB标准课程

网页制作Webjx文章简介:在这篇文章里,我要向大家介绍我和其他很多人花费数月时间开发的一个课程——Web标准课程,该课程旨在向大家提供Web设计和开发的坚实基础,无论读者是谁,此教程完全免费、可访问,并且不需要预备知识。当然,我主要还
收藏 0 赞 0 分享

CSS样式表渐进增强的基本概念

网页制作Webjx文章简介:如果你挠着头想弄清楚优雅降级和渐进增强的区别,我告诉你,这是视角问题。优雅降级和渐进增强都考虑网站在各种设备的各种浏览器上如何良好运转。两者区别的关键在于它们各自关注的焦点,以及这种关注对工作流程的影响
收藏 0 赞 0 分享

简单介绍Web Developer插件制作网页

网页制作Webjx文章简介:Firefox浏览器是一个良好支持W3C标准的开放源代码的浏览器,拥有Linux/Windows/Mac版本。因为Firefox浏览器良好支持W3C标准,所以使用Firefox来调试网页是非常好的。 Firefox浏览器是
收藏 0 赞 0 分享

CSS布局带来的巨大影响:CSS display属性值

网页制作Webjx文章简介:网页元素应用上那些与表格相关的display属性值后,能够模仿出与表格相同的特性。我将会在该文中给大家演示这种方法给CSS布局带来的巨大影响。 应原书编辑要求,先在文章顶部给出链接:《Everything You
收藏 0 赞 0 分享

用div css模拟表格对角线

这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点。如果对此深以为然的朋友,请一笑过之 首先声明: 这只是探讨一种CSS模拟表格对角线的
收藏 0 赞 0 分享

IE Firefox在css中的差别 (部分)

1、单位问题 问题:任何距离的数值ie可以不加单位,ff必须要求写单位(0除外) 解决:写全单位如padding:0px; 2、水平居中 问题:div里的内容,ie默认为center,而ff默认left 解决:mairgin:0px auto; 3、高度问题
收藏 0 赞 0 分享

不用js可以实现信息提示效果

[code] <style> body { font:verdena; font-size:14px; color:#000 } h1{ font:verdena; font-size:22px; color:#000 } h2{ font:verdena;
收藏 0 赞 0 分享

CSS解决未知高度的垂直水平居中自适应问题

今天有人问起,晚上试着写出来,供参考; 以下代码兼容主流浏览器IE6、IE7、Firefox、Opera。 从最简单的开始………… 一、如何让一个DIV水平居中? 这个简单不作过多说明! [code] <st
收藏 0 赞 0 分享

CSS cursor 属性 -- 鼠标指针样式效果

取值: [ [<uri> ,]* [ auto | crosshair | default | pointer | move | e-resize | ne-resize | nw-resize | n-resize | se-resize | sw-resize |
收藏 0 赞 0 分享

css 简单区别ie6,ie7,firefox的写法

同一样式里可以这样 [code] margin:17px; FF +margin:17px; IE6 IE7 _margin:17px; IE6 [/code] 按这个顺序,刚好区分开三个浏览器
收藏 0 赞 0 分享
查看更多