摘要:如何解決移動端的自適應問題主要是移動端的屏幕尺寸比較多,如何在各種屏幕寬度下顯示的更好,更一致問題。用解決自適應的問題,是個非常精確的解決方案,能夠將高度和寬度都做到隨著屏幕的寬度完全的等比縮放,但是缺點就是開發起來效率低點。
1.背景知識
首先是看幾篇文章,了解viewport scale dpr 圖片的顯示精度問題 一像素顯示問題, 縮放導致的像素適應問題 移動端的自適應問題
http://www.cnblogs.com/520yan...
http://www.cnblogs.com/520yan...
https://mp.weixin.qq.com/s?__...
https://github.com/amfe/artic...
1、圖片精度問題其實圖片顯示高清的問題,最理想的方案是根據dpr去加載不同精度的圖片,但是一般這個工作效果不是很明顯,直接顯示精度大的圖片就可以了,雖然在dpr是1的屏幕上會費流量、有點色差 但是完全可以忽略。
所以圖片這個問題還好。
1px顯示的問題,利用縮放解決
一般設計給的設計稿都是針對iphone6的750px 1334px ,但是iphone6的設備獨立像素是375px667px iphone6的dpr=2
所以如果我們把viewport設成375px的話,就無法顯示設計稿中1px的元素。
所以為了顯示1px,我們需要將viewport設成750px,然后設置scale=0.5,這樣手機屏幕還是完整的顯示頁面,并且使得css中的px
和手機物理設備的px相同了。
但是scale的縮放會影響原來的像素大小,比如在scale=1時,一個元素應該是12px 但是scale=0.5時,整體頁面縮小了1倍,這個元素的大小應該是24px,才能和原來顯示一樣。
4、利用rem解決像素適應的問題,在dpr=2的時候設html的font-size=100px,在dpr=1的時候設置font-size=50。然后需要在不同dpr下顯示不同px的地方就可以以rem為單位進行設置。
那么為什么把dpr=2的時候設置font-size=100, 因為設計稿給的是iphone6 dpr=2的情況下的像素,所以根據設計稿換算起來比較簡單,比如設計稿中font-size: 24px。我們可以直接寫font-size:0.24rem。 這樣在dpr=2的時候顯示成24px 在dpr=1的時候顯示成12px。
主要是移動端的屏幕尺寸比較多,如何在各種屏幕寬度下顯示的更好,更一致問題。
比較簡單的辦法就是百分比或者flex。
以后深入研究下百分比和flex的使用。
比如750px,我們可以把所有元素flex的總和設成750px,比如左邊flex 300 右邊 flex450 就是 300比450的自適應。
百分比要注意的是他所設置的百分比 是父元素的寬度為基礎的。
然后還要考慮的是高度的問題,高度怎么去適應。圖片的話高度會隨著寬度等比例縮放。
用rem解決自適應的問題,是個非常精確的解決方案,能夠將高度和寬度都做到隨著屏幕的寬度完全的等比縮放,但是缺點就是開發起來效率低點。來看看如何操作。
首先還是會根據dpr 來設置viewport的寬度和scale的縮放級別
然后設計成頁面的寬度是10rem,
1rem = 頁面寬度/10 = device-width * dpr /10;
以iphone6為例
1rem = 375 * 2 /10 = 75px;
所以設
html {
font-size = 75px;
}
然后把html加一個屬性data-dpr = 2;
示例代碼如下:
javascript方式,通過上面的公式,計算出基準值rem,然后寫入樣式,大概如下(代碼參考自kimi的m-base模塊) var dpr, rem, scale; var docEl = document.documentElement; var fontEl = document.createElement("style"); var metaEl = document.querySelector("meta[name="viewport"]"); dpr = window.devicePixelRatio || 1; rem = docEl.clientWidth * dpr / 10; scale = 1 / dpr; // 設置viewport,進行縮放,達到高清效果 metaEl.setAttribute("content", "width=" + dpr * docEl.clientWidth + ",initial-scale=" + scale + ",maximum-scale=" + scale + ", minimum-scale=" + scale + ",user-scalable=no"); // 設置data-dpr屬性,留作的css hack之用 docEl.setAttribute("data-dpr", dpr); // 動態寫入樣式 docEl.firstElementChild.appendChild(fontEl); fontEl.innerHTML = "html{font-size:" + rem + "px!important;}"; // 給js調用的,某一dpr下rem和px之間的轉換函數 window.rem2px = function(v) { v = parseFloat(v); return v * rem; }; window.px2rem = function(v) { v = parseFloat(v); return v / rem; }; window.dpr = dpr; window.rem = rem;
這樣的實現,就能夠完全的將設計稿中的px對應成rem,并且能夠根據屏幕的寬度進行自適應。
有兩個問題:
第一個問題是設計稿到rem的轉換降低開發效率
比如設計稿750px,1rem = 75px。 設計稿上的50px,我們需要計算出50/75 rem
第二個問題是 rem設置成device-width的10分之一,縮放引起的字體的大小變化就不能用rem來解決了
因為我們一般只是想在不同縮放下,一起縮放字體,而字體不需要自適應。
字體應該是在任何屏幕上字體都應該保持一致。
先說第二個問題:
這個就可以利用CSS實現
思路 因為已經在html上設置data=dpr
font-size: 16px; [data-dpr="2"] input { font-size: 32px; }
可以用sass寫成一個mixin
@mixin dpr($property, $value) { & { #{$property}: $value / 2; /* no */ } [data-dpr="2"] & { #{$property}: $value; /* no */ } [data-dpr="3"] & { #{$property}: $value * 1.5; /* no */ } } @mixin font-size($fontSize) { @include dpr(font-size, $fontSize); }
這樣用的地方可以這樣寫
@include font-size(52px);
再說第一個問題px到rem的轉換問題
淘寶的rem庫,lib-flexible
https://github.com/amfe/artic...
這篇文章里說了幾種方法
有sublime的插件,有sass的處理函數,有gulp的插件,
我們現在都用webpack做開發,和打包,所以用一個webpack的插件px2rem-loader
這個插件可以實現我們直接寫px 打包的時候自動轉換成rem
CSS的loader中加入px2rem插件
const REM_UNIT = 75; let px2rem = `px2rem?remUnit=${REM_UNIT}&remPrecision=8&threeVersion=true`; return { css: generateLoaders([ "css" , px2rem]), postcss: generateLoaders([ "css" , px2rem]), less: generateLoaders([ "css", px2rem , "less" ]), sass: generateLoaders([ "css", px2rem , "sass?indentedSyntax" ]), scss: generateLoaders([ "css", px2rem , "sass" ]), stylus: generateLoaders([ "css", px2rem , "stylus" ]), styl: generateLoaders([ "css", px2rem, "stylus" ]) }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/82111.html
摘要:背景現在工作中有超過一半的時間用于移動端項目的開發,包括嵌入頁,微信頁面和移動頁。經過研究,我在公司的多個移動端項目使用了布局來解決移動端自適應布局的問題。簡單的說它就是一個相對單位,布局是一個流行的解決移動端響應式布局的方案。 背景 現在工作中有超過一半的時間用于移動端項目的開發,包括app嵌入頁,微信頁面和移動wap頁。 開發移動端頁面跟開發PC頁面的一個大區別就是移動端對響應式布...
摘要:已更新強力推薦移動端自適應解決方案與仿原生超高清超細膩解決方案新增了功能,開啟了功能后,可以自動設置設備尺寸為物理分辨率使網頁達到原生精細效果。 已更新 - 強力推薦 (移動端自適應解決方案與仿原生APP超高清超細膩解決方案)https://gitlab.com/fekits/mc-... v1.1.0 [Latest version] 1、新增了dpr功能,開啟了DPR功能后,可以...
摘要:本文同步發布于我的個人博客上移動端自適應布局不管是面試還是工作過程中,移動端的布局都比較常見,而移動端適配方法也是多種多樣。表示當前視口寬度的百分之一。同時在移動端,的兼容性還不錯,完全可以直接使用。這樣完成了一個簡單好用的移動端布局了 本文同步發布于我的個人博客上 - vw+rem移動端自適應布局 不管是面試還是工作過程中,移動端的布局都比較常見,而移動端適配方法也是多種多樣。一般來...
閱讀 3244·2021-11-22 12:07
閱讀 1884·2021-10-12 10:11
閱讀 1048·2019-08-30 15:44
閱讀 2948·2019-08-30 12:45
閱讀 2200·2019-08-29 16:41
閱讀 1644·2019-08-29 16:35
閱讀 2631·2019-08-29 12:57
閱讀 1156·2019-08-26 13:51