移動端頁面使用rem布局
阿新 • • 發佈:2017-09-07
cnblogs rem user highlight 高清 方案 base div font
阿裏團隊的高清布局方案代碼
所謂高清方案就是根據設備屏幕的DPR(設備像素比,又稱DPPX,比如dpr=2時,表示1個CSS像素由4個物理像素點組成)
動態設置 html 的font-size, 同時根據設備DPR調整頁面的縮放值,進而達到高清效果**。
var _baseFontSize = baseFontSize || 100; var _fontscale = fontscale || 1; var win = window; var doc = win.document; var ua = navigator.userAgent; var matches = ua.match(/Android[\S\s]+AppleWebkit\/(\d{3})/i); var UCversion = ua.match(/U3\/((\d+|\.){5,})/i); var isUCHd = UCversion && parseInt(UCversion[1].split(‘.‘).join(‘‘), 10) >= 80; var isIos = navigator.appVersion.match(/(iphone|ipad|ipod)/gi); var dpr = win.devicePixelRatio || 1; if (!isIos && !(matches && matches[1] > 534) && !isUCHd) { // 如果非iOS, 非Android4.3以上, 非UC內核, 就不執行高清, dpr設為1; dpr = 1; } var scale = 1 / dpr; var metaEl = doc.querySelector(‘meta[name="viewport"]‘); if (!metaEl) { metaEl = doc.createElement(‘meta‘); metaEl.setAttribute(‘name‘, ‘viewport‘); doc.head.appendChild(metaEl); } metaEl.setAttribute(‘content‘, ‘width=device-width,user-scalable=no,initial-scale=‘ + scale + ‘,maximum-scale=‘ + scale + ‘,minimum-scale=‘ + scale); doc.documentElement.style.fontSize = _baseFontSize / 2 * dpr * _fontscale + ‘px‘; })();
註意:並不是所有地方都適用rem 寬度最好還是用百分比
移動端頁面使用rem布局