该问题的原因就是web 根元素的fontsize值,没有固定。所以才会导致页面rem的值不固定,从而闪现布局。
解决方案就是在网页加载之前就把,fontsize值计算好并且固定住,就能解决。
方法1
用媒体查询解决
@media (min-width: 320px){html{font-size: 42.6667px;} }
@media (min-width: 360px){html{font-size: 48px;} }
@media (min-width: 375px){html{font-size: 50px;} }
@media (min-width: 384px){html{font-size: 51.2px;} }
@media (min-width: 414px){html{font-size: 55.2px;} }
@media (min-width: 448px){html{font-size: 59.7333px;} }
@media (min-width: 480px){html{font-size: 48px;} }
@media (min-width: 512px){html{font-size: 68.2667px;} }
@media (min-width: 544px){html{font-size: 72.5333px;} }
@media (min-width: 576px){html{font-size: 76.8px;} }
@media (min-width: 608px){html{font-size: 81.0667px;} }
@media (min-width: 640px){html{font-size: 85.3333px;} }
@media (min-width: 750px){html{font-size: 100px;} }
1.html{font-size: 50px;}//这个一定写
2.JS动态计算和密集的媒体查询二选一
方法2
<script>
//common js脚本
function resize(){
var htmlEle = document.documentElement;
var htmlwidth = window.innerWidth; //浏览器时下窗口可视区域宽度
// var rem = (win_width*20/2000); //这个比例最好要和设计稿比例一致
htmlEle.style.fontsize = htmlwidth*20/2000+'px';
}
resize();
</script>
此篇是本人经多次查找资料和修改,
如有问题请联系小编
如有不足请包涵
rem的两个方法 媒体查询 js
最新推荐文章于 2024-05-24 13:49:10 发布