移动端适配-动态计算rem
2020-03-17 16:01:19来源:博客园 阅读 ()
移动端适配-动态计算rem
直接以750px设计稿为例:
(function(designWidth, maxWidth) { var doc = document, win = window; var docEl = doc.documentElement; var remStyle = document.createElement("style"); //获取基准字体大小 function refreshRem() { // var width = parseInt(window.screen.width); // uc有bug var width = docEl.getBoundingClientRect().width; if (!maxWidth) { maxWidth = 750; }; if (width > maxWidth) { width = maxWidth; } var rem = width/designWidth*100; //得到的rem基准字体大小,这里乘以100是为了适配有的浏览器不识别小数,会导致设置字体无效。 //设置根元素html的字体大小为基准字体大小,在css中每rem就是这个值的大小。 remStyle.innerHTML = 'html{font-size:' + rem + 'px;} '; } refreshRem(); if (docEl.firstElementChild) { docEl.firstElementChild.appendChild(remStyle); } else { var wrap = doc.createElement("div"); wrap.appendChild(remStyle); doc.write(wrap.innerHTML); wrap = null; } /* 以下为在不同的时机重新计算rem*/ win.addEventListener("resize", function() { // clearTimeout(tid); //防止执行两次 // tid = setTimeout(refreshRem, 50); refreshRem() }, false); win.addEventListener("pageshow", function(e) { if (e.persisted) { // 浏览器后退的时候重新计算 refreshRem() // clearTimeout(tid); // tid = setTimeout(refreshRem,50); } }, false); })(750, 750);
另外找了两篇说的比较细的文章,链接如下:
https://www.cnblogs.com/hjptopshow/p/9382448.html
https://www.cnblogs.com/Sky-Ice/p/9596420.html
原文链接:https://www.cnblogs.com/zhinian-/p/12511239.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 循序渐进VUE+Element 前端应用开发(3)--- 动态菜单和路由的 2020-05-27
- 取消a标签在移动端点击时的背景颜色 2020-03-19
- 移动端性能优化(HTML性能优化) 2020-03-17
- 移动端常见问题(动画演示) 2020-03-17
- 移动端常见问题(click 300ms延迟) 2020-03-17
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash