关于移动端简单适配字体大小hostcss

采用flex+rem的方式进行布局和完成移动端的适配host.js

基于 flexible方案的 hotcss

rem(font size of the root element)是相对长度单位。
相对于根元素(即html元素)font-size计算值的倍数。

适配原理:将px替换成rem,动态修改html的font-size适配。
它可以很好的根据根元素的字体大小来进行变化,从而达到各种
屏幕基本一直的效果体验

三行js代码简单适配

//得到手机屏幕的宽度
let htmlWidth = document.documentElement.clientWidth || document.body.clientWidth;

// 但页面很大的时候,我们作的移动适配方案会呈现很大的字体,
//这不是我们想要的。所以加一个判断,解决页面字体过大的问题。
if(htmlWidth > 750){htmlWidth=750}

//得到html的Dom元素
let htmlDom = document.getElementsByTagName('html')[0];
//设置根元素字体大小
htmlDom.style.fontSize= htmlWidth/20 + 'px';
然后监听一下 窗口改变

参考小米官网

!function(n){
    var  e=n.document,
         t=e.documentElement,
         i=720,
         d=i/100,
         o="orientationchange"in n?"orientationchange":"resize",
         a=function(){
             var n=t.clientWidth||320;n>720&&(n=720);
             t.style.fontSize=n/d+"px"
         };
         e.addEventListener&&(n.addEventListener(o,a,!1),e.addEventListener("DOMContentLoaded",a,!1))
}(window);

按设计图走

window.onload = function(){
    /*720代表设计师给的设计稿的宽度,你的设计稿是多少,就写多少;100代表换算比例,这里写100是
      为了以后好算,比如,你测量的一个宽度是100px,就可以写为1rem,以及1px=0.01rem等等*/
    getRem(720,100)
};
window.onresize = function(){
    getRem(720,100)
};
function getRem(pwidth,prem){
    var html = document.getElementsByTagName("html")[0];
    var oWidth = document.body.clientWidth || document.documentElement.clientWidth;
    html.style.fontSize = oWidth/pwidth*prem + "px";
}

你可能感兴趣的:(关于移动端简单适配字体大小hostcss)