css中px em rem vw vh vmax vmin等單位的區別--轉載

px:絕對單位,頁面按精確像素展現javascript

em:相對單位,基準點爲父節點字體的大小,若是自身定義了font-size按自身來計算(瀏覽器默認字體是16px),整個頁面內1em不是一個固定的值。html

rem:相對單位,可理解爲」root em」, 相對根節點html的字體大小來計算,CSS3新加屬性,chrome/firefox/IE9+支持。java

(另外需注意chrome強制最小字體爲12號,即便設置成 10px 最終都會顯示成 12px,當把html的font-size設置成10px,子節點rem的計算仍是以12px爲基準,因此網上不少文章提到的將html的font-size設爲10方便計算不是那麼可取)。android

rem在移動端應用可參考淘寶的頁面http://m.taobao.com (html的font-size經過動態計算獲取)ios

頁面基準320px(20px),html font-size值的計算:chrome

  1. var ele=document.getElementsByTagName("html")[0],  
  2.      size=document.body.clientWidth/320*20;  
  3. ele.style.fontSize=size+"px"  

注:需設置meta縮放比1:1
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no" />瀏覽器

 

 

vw:viewpoint width,視窗寬度,1vw等於視窗寬度的1%。
vh:viewpoint height,視窗高度,1vh等於視窗高度的1%。
vmin:vw和vh中較小的那個。
vmax:vw和vh中較大的那個。字體

vw, vh, vmin, vmax:IE9+局部支持,chrome/firefox/safari/opera支持,iOS safari 8+支持,Android browser4.4+支持,chrome for android39支持spa

 

其它的單位還有:
%:百分比
in:寸
cm:釐米
mm:毫米
pt:point,大約1/72寸firefox

pc:pica,大約6pt,1/6寸

 

ex:取當前做用效果的字體的x的高度,在沒法肯定x高度的狀況下以0.5em計算(IE11及如下均不支持,firefox/chrome/safari/opera/ios safari/android browser4.4+等均需屬性加麼有前綴)

ch:以節點所使用字體中的「0」字符爲基準,找不到時爲0.5em(ie10+,chrome31+,safair7.1+,opera26+,ios safari 7.1+,android browser4.4+支持)

相關文章
相關標籤/搜索