码迷,mamicode.com
首页 > 其他好文 > 详细

单位rem 触屏适配总结

时间:2015-08-05 17:40:52      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:

来源:http://www.cnblogs.com/dtdxrk/p/4644703.html

先了解一下rem

css3 中引入了新的长度单位,rem。  官方定义 font size of the root element

rem:rem和em单位一样,都是一个相对单位。不同的是em是相对于元素的父元素的font-size进行计算;rem是相对于根元素html的font-size进行计算。这样一来rem就绕开了复杂的层级关系,实现了类似于em单位的功能。

兼容性:IE9+,Firefox、Chrome、Safari、Opera 的主流版本都支持。(IE6-8不支持  不过考虑是移动端web app  )

技术分享

 

设置rem的小练习

html的font-size设置为20px

1
2
html{font-size: 20px;}
        button{width: 5rem;height: 2rem;color: #fff;font-size: 1.2rem;border:0;}

技术分享  

 

html的font-size设置为40px

技术分享

 

从这个小练习里就可以知道rem单位元素的大小是根据html font-size变化的,这就是rem做适配的原理。

 

rem用法很简单,就是根标签html设置文字大小后(不设置的话,大部份浏览器默认为16px),其他标签设置rem都是html大小的倍数。

1
2
3
4
5
6
html{
    font-size: 10px; /* 设置html为10px */
}
h1{
    font-size: 2rem; /* 10px*2=20px */
}

  

rem切稿开发

那么我们怎么把设计稿里的单位转换成rem进行开发呢?

首先假设我的页面设计稿给我时候是按照640的标准尺寸给我的前提下,(当然这个尺寸肯定不一定是640,可以是320,或者480,又或是375)来看一组表格。

技术分享

屏幕根据设计稿的比例转换对应的rem值,比如:

640的设置 = 20*(clientWidth/320) 

320的设置 = 10*(clientWidth/320) 

设置html font-size的工作我们交给js去实现,所以我的切稿元素都按照 (元素设计稿px/20 = 最终的rem):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
/*rem adaptation*/
(function (doc, win) {
  var docEl = doc.documentElement,
      resizeEvt = ‘orientationchange‘ in window ? ‘orientationchange‘ ‘resize‘,
      recalc = function () {
        var clientWidth = docEl.clientWidth;
        if (!clientWidth) return;
        docEl.style.fontSize = 10*(clientWidth / 320) + ‘px‘;
      };
 
  recalc();
  if (!doc.addEventListener) return;
  win.addEventListener(resizeEvt, recalc, false);
  // doc.addEventListener(‘DOMContentLoaded‘, recalc, false);
 
})(document, window);

  

 

最后再看一下实例效果:

技术分享

所有元素margin padding font-size width height都是rem

1
2
3
4
*{margin:0;padding:0;}
        .box {padding:10rem;}
        .box p{font-size:12rem;line-height: 20rem;}
        .box a{display: block;line-height: 40rem;text-align: center;color: #fff; font-size:16rem;margin-top:12rem;}

技术分享

单位rem 触屏适配总结

标签:

原文地址:http://www.cnblogs.com/ajieyingqulvxing/p/4705161.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!