登山则情满于山,观海则意溢于海。这篇文章主要讲述安卓4.0下rem显示不正常的问题相关的知识,希望能为你提供帮助。
【安卓4.0下rem显示不正常的问题】在项目中使用了rem为单位,结果在Oppo和4.0下某些浏览器rem工作不正常,font-size计算出来的px总是大于预期的值,因此加了个Hack
var docEl = doc.documentElement,
resizeEvt = ‘orientationchange‘ in window ? ‘orientationchange‘ : ‘resize‘,
recalc = function() {
var clientWidth = docEl.clientWidth;
if (!clientWidth) return;
docEl.style.fontSize = 100 * (clientWidth / 320) + ‘px‘;
correctPx()
};
// 校正
function correctPx(){
var docEl = document.documentElement;
var clientWidth = docEl.clientWidth;
if (!clientWidth) return;
var div = document.createElement(‘div‘);
div.style.width = ‘1.4rem‘;
div.style.height = ‘0‘;
document.body.appendChild(div);
var ideal = 140 * clientWidth / 320;
var rmd = (div.clientWidth / ideal);
if(rmd > 1.2)
docEl.style.fontSize = 100 * (clientWidth / 320)/ rmd + ‘px‘;
document.body.removeChild(div);
}
// Abort if browser does not support addEventListener
if (!doc.addEventListener) return;
win.addEventListener(resizeEvt, recalc, false);
doc.addEventListener(‘DOMContentLoaded‘, recalc, false);
推荐阅读
- Android tools:context=".MainActivity"的作用
- Android布局6大类
- Android中的五大布局
- 如何在PHP中将字符串转换为数字()
- jQuery如何设置输入文本字段的值(代码实例)
- Java如何删除文件(代码实现详细示例)
- 算法(如何计算乘积和总和相等的子数组的个数())
- jQuery如何使用星号*选择器(代码实例)
- Java实现Dijkstra算法并打印路径详细代码