js动态计算移动端rem

在做移动端web app的时候,众所周知,移动设备分辨率五花八门,虽然我们可以通过CSS3的media query来实现适配,例如下面这样:

 1 html {
 2         font-size : 20px;
 3     }
 4     @media only screen and (min-width: 401px){
 5         html {
 6             font-size: 25px !important;
 7         }
 8     }
 9     @media only screen and (min-width: 428px){
10         html {
11             font-size: 26.75px !important;
12         }
13     }
14     @media only screen and (min-width: 481px){
15         html {
16             font-size: 30px !important;
17         }
18     }
19     @media only screen and (min-width: 569px){
20         html {
21             font-size: 35px !important;
22         }
23     }
24     @media only screen and (min-width: 641px){
25         html {
26             font-size: 40px !important;
27         }
28     }

但是这种做法并不能适配所有设备,于是就有了实现全适配的JS解决方案,例如下面这样:

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

另外附上淘宝移动端适配解决方案flexible.js源码:

  1 ;(function(win, lib) {
  2     var doc = win.document;
  3     var docEl = doc.documentElement;
  4     var metaEl = doc.querySelector(‘meta[name="viewport"]‘);
  5     var flexibleEl = doc.querySelector(‘meta[name="flexible"]‘);
  6     var dpr = 0;
  7     var scale = 0;
  8     var tid;
  9     var flexible = lib.flexible || (lib.flexible = {});
 10
 11     if (metaEl) {
 12         //将根据已有的meta标签来设置缩放比例
 13         var match = metaEl.getAttribute(‘content‘).match(/initial\-scale=([\d\.]+)/);
 14         if (match) {
 15             scale = parseFloat(match[1]);
 16             dpr = parseInt(1 / scale);
 17         }
 18     } else if (flexibleEl) {
 19         var content = flexibleEl.getAttribute(‘content‘);
 20         if (content) {
 21             var initialDpr = content.match(/initial\-dpr=([\d\.]+)/);
 22             var maximumDpr = content.match(/maximum\-dpr=([\d\.]+)/);
 23             if (initialDpr) {
 24                 dpr = parseFloat(initialDpr[1]);
 25                 scale = parseFloat((1 / dpr).toFixed(2));
 26             }
 27             if (maximumDpr) {
 28                 dpr = parseFloat(maximumDpr[1]);
 29                 scale = parseFloat((1 / dpr).toFixed(2));
 30             }
 31         }
 32     }
 33
 34     if (!dpr && !scale) {
 35         var isAndroid = win.navigator.appVersion.match(/android/gi);
 36         var isIPhone = win.navigator.appVersion.match(/iphone/gi);
 37         var devicePixelRatio = win.devicePixelRatio;
 38         if (isIPhone) {
 39             // iOS下,对于2和3的屏,用2倍的方案,其余的用1倍方案
 40             if (devicePixelRatio >= 3 && (!dpr || dpr >= 3)) {
 41                 dpr = 3;
 42             } else if (devicePixelRatio >= 2 && (!dpr || dpr >= 2)){
 43                 dpr = 2;
 44             } else {
 45                 dpr = 1;
 46             }
 47         } else {
 48             // 其他设备下,仍旧使用1倍的方案
 49             dpr = 1;
 50         }
 51         scale = 1 / dpr;
 52     }
 53
 54     docEl.setAttribute(‘data-dpr‘, dpr);
 55     if (!metaEl) {
 56         metaEl = doc.createElement(‘meta‘);
 57         metaEl.setAttribute(‘name‘, ‘viewport‘);
 58         metaEl.setAttribute(‘content‘, ‘initial-scale=‘ + scale + ‘, maximum-scale=‘ + scale + ‘, minimum-scale=‘ + scale + ‘, user-scalable=no‘);
 59         if (docEl.firstElementChild) {
 60             docEl.firstElementChild.appendChild(metaEl);
 61         } else {
 62             var wrap = doc.createElement(‘div‘);
 63             wrap.appendChild(metaEl);
 64             doc.write(wrap.innerHTML);
 65         }
 66     }
 67
 68     function refreshRem(){
 69         var width = docEl.getBoundingClientRect().width;
 70         if (width / dpr > 540) {
 71             width = 540 * dpr;
 72         }
 73         var rem = width / 10;
 74         docEl.style.fontSize = rem + ‘px‘;
 75         flexible.rem = win.rem = rem;
 76     }
 77
 78     win.addEventListener(‘resize‘, function() {
 79         clearTimeout(tid);
 80         tid = setTimeout(refreshRem, 300);
 81     }, false);
 82     win.addEventListener(‘pageshow‘, function(e) {
 83         if (e.persisted) {
 84             clearTimeout(tid);
 85             tid = setTimeout(refreshRem, 300);
 86         }
 87     }, false);
 88
 89     if (doc.readyState === ‘complete‘) {
 90         doc.body.style.fontSize = 12 * dpr + ‘px‘;
 91     } else {
 92         doc.addEventListener(‘DOMContentLoaded‘, function(e) {
 93             doc.body.style.fontSize = 12 * dpr + ‘px‘;
 94         }, false);
 95     }
 96
 97
 98     refreshRem();
 99
100     flexible.dpr = win.dpr = dpr;
101     flexible.refreshRem = refreshRem;
102     flexible.rem2px = function(d) {
103         var val = parseFloat(d) * this.rem;
104         if (typeof d === ‘string‘ && d.match(/rem$/)) {
105             val += ‘px‘;
106         }
107         return val;
108     }
109     flexible.px2rem = function(d) {
110         var val = parseFloat(d) / this.rem;
111         if (typeof d === ‘string‘ && d.match(/px$/)) {
112             val += ‘rem‘;
113         }
114         return val;
115     }
116
117 })(window, window[‘lib‘] || (window[‘lib‘] = {}));

flexible.js

时间: 2024-11-09 02:15:31

js动态计算移动端rem的相关文章

还能输入多少字?(JS动态计算)

<div class="m-form ovh"> <div class="hd"> <span class="fr" id="message">还能输入200个字</span> 我要说: <select name="select" id="select"> <option value="12">北

浅谈移动端的自适应问题——响应式、rem/em、利用Js动态实现移动端自适应

随着3G的普及,越来越多的人使用手机上网.移动设备正超过桌面设备,成为访问互联网的最常见终端.于是,网页设计师不得不面对一个难题:如何才能在不同大小的设备上呈现同样的网页?本篇文章将讲述自适应网页设计的概念和方法,使网页开发人员维护同一个网页代码,即可使网站在多种设备上具有更好的阅读体验.本文详细介绍了自适应网页的实现方法,希望能给迷惑的你带来帮助. 一. 在HTML的头部加入meta标签 在HTML的头部,也就是head标签中增加meta标签,告诉浏览器网页宽度等于设备屏幕宽度,且不进行缩放,

js动态适配移动端font-size,单位:rem

比如:目前我手中有一张psd图,大小为640*1010,适配苹果5的手机. 方法步骤: 1.我采用font-size=10px为640*1010手机的初始像素大小:  1rem=10px: 此时psd上有一个文字的大小为20px,即当前我的字体大小用rem表示为:font-size:1rem  (psd上的大小为html上大小的2倍,so首先要除以2才能得到正确的px,之后换算rem再次除以2就ok了) 适配各种手机的rem单位: 2.获取我当前使用手机的width:   var windowW

第148天:js+rem动态计算font-size的大小,适配各种手机设备

需求: 在不同的移动终端设备中实现,UI设计稿的等比例适配. 方案: 布局排版都用rem做单位,然后不同宽度的屏,js动态计算根节点的font-size. 假设设计稿是宽750px来做的,书写css方便计算考虑,根节点的font-size假定为100px,得出设备宽为7.5rem.设计稿中标注的任何px数值都可以换算成px/100的rem值. 就是说,每一个设备的宽度都定为7.5个rem,然后宽度非750px的设备里,就需要用JS对font-size做动态计算. 换算关系为:根节点的font-s

根据iPhone6设计稿动态计算rem值

rem 单位在做移动端的h5开发的时候是最经常使用的单位.为解决自适应的问题,我们需要动态的给文档的更节点添加font-size 值.使用mediaquery 可以解决这个问题,但是每一个文件都引用一大串的font-size 值很繁琐,而且值也不能达到连续的效果. 就使用js动态计算给文档的fopnt-size 动态赋值解决问题. /** * [以iPhone6的设计稿为例js动态设置文档 rem 值] * @param {[type]} doc [文档元素] * @param {[type]}

移动端rem单位用法[转]

标签: 1.rem(font size of the root element)是指相对于根元素的字体大小的单位,em(font size of the element)是指相对于父元素的字体大小的单位.它们之间其实很相似,只不过一个计算的规则是依赖根元素一个是依赖父元素计算.二者都是相对单位 2.我们现在在切页面布局的使用常用的单位是px,这是一个绝对单位,web app的屏幕适配有很多中做法, 例如:流式布局.限死宽度,还有就是通过响应式来做,但是这些方案都不是最佳的解决方法, 例如流式布局

移动端rem单位用法

1.rem(font size of the root element)是指相对于根元素的字体大小的单位,em(font size of the element)是指相对于父元素的字体大小的单位.它们之间其实很相似,只不过一个计算的规则是依赖根元素一个是依赖父元素计算.二者都是相对单位 2.我们现在在切页面布局的使用常用的单位是px,这是一个绝对单位,web app的屏幕适配有很多中做法,例如:流式布局.限死宽度,还有就是通过响应式来做,但是这些方案都不是最佳的解决方法, 例如流式布局的解决方案

移动端rem的用法

标签: 1.rem(font size of the root element)是指相对于根元素的字体大小的单位,em(font size of the element)是指相对于父元素的字体大小的单位.它们之间其实很相似,只不过一个计算的规则是依赖根元素一个是依赖父元素计算.二者都是相对单位 2.我们现在在切页面布局的使用常用的单位是px,这是一个绝对单位,web app的屏幕适配有很多中做法, 例如:流式布局.限死宽度,还有就是通过响应式来做,但是这些方案都不是最佳的解决方法, 例如流式布局

详解移动端rem变革

作者:侠名风 |  时间:2015-07-24 |  浏览:93 |  0 条评论 rem这是个低调的css单位,近一两年开始崭露头角,有许多同学对rem的评价不一,有的在尝试使用,有的在使用过程中遇到坑就弃用了.但是我对rem综合评价是用来做web app它绝对是最合适的人选之一. rem是什么? rem(font size of the root element)是指相对于根元素的字体大小的单位.简单的说它就是一个相对单位.看到 rem大家一定会想起em单位,em(font size of