關於移動端簡單適配字體大小 rem + flex佈局

採用flex+rem的方式進行佈局和完成移動端的適配
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";
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章