淺談移動(dòng)端適配

https://github.com/sunmaobin/sunmaobin.github.io/issues/27
http://div.io/topic/1092

移動(dòng)端相關(guān)問(wèn)題:

1活逆、border: 1px問(wèn)題
2、圖片高清問(wèn)題
3哨鸭、屏幕適配布局問(wèn)題

CSS中的1px并不等于設(shè)備的1px

在css中我們一般使用px作為單位黍檩,在桌面瀏覽器中css的1個(gè)像素往往都是對(duì)應(yīng)著電腦屏幕的1個(gè)物理像素氓栈,這可能會(huì)造成我們的一個(gè)錯(cuò)覺(jué),那就是css中的像素就是設(shè)備的物理像素驶忌。但實(shí)際情況卻并非如此戴尸,css中的像素只是一個(gè)抽象的單位,在不同的設(shè)備或不同的環(huán)境中琅捏,css中的1px所代表的設(shè)備物理像素是不同的生百。在為桌面瀏覽器設(shè)計(jì)的網(wǎng)頁(yè)中,我們無(wú)需對(duì)這個(gè)津津計(jì)較柄延,但在移動(dòng)設(shè)備上蚀浆,必須弄明白這點(diǎn)缀程。在早先的移動(dòng)設(shè)備中,屏幕像素密度都比較低市俊,如iphone3杨凑,它的分辨率為320x480,在iphone3上摆昧,一個(gè)css像素確實(shí)是等于一個(gè)屏幕物理像素的撩满。后來(lái)隨著技術(shù)的發(fā)展,移動(dòng)設(shè)備的屏幕像素密度越來(lái)越高绅你,從iphone4開(kāi)始伺帘,蘋(píng)果公司便推出了所謂的Retina屏,分辨率提高了一倍忌锯,變成640x960伪嫁,但屏幕尺寸卻沒(méi)變化,這就意味著同樣大小的屏幕上偶垮,像素卻多了一倍张咳,這時(shí),一個(gè)css像素是等于兩個(gè)物理像素的针史。
還有一個(gè)因素也會(huì)引起css中px的變化晶伦,那就是用戶縮放碟狞。例如啄枕,當(dāng)用戶把頁(yè)面放大一倍,那么css中1px所代表的物理像素也會(huì)增加一倍族沃;反之把頁(yè)面縮小一倍频祝,css中1px所代表的物理像素也會(huì)減少一倍。

一些概念

物理像素(physical pixel)

一個(gè)物理像素是顯示器(手機(jī)屏幕)上最小的物理顯示單元脆淹,在操作系統(tǒng)的調(diào)度下常空,每一個(gè)設(shè)備像素都有自己的顏色值和亮度值。

設(shè)備獨(dú)立像素(density-independent pixel)

設(shè)備獨(dú)立像素(也叫密度無(wú)關(guān)像素)盖溺,可以認(rèn)為是計(jì)算機(jī)坐標(biāo)系統(tǒng)中的一個(gè)點(diǎn)漓糙,這個(gè)點(diǎn)代表一個(gè)可以由成有程序使用的虛擬像素(比如:css像素),然后由相關(guān)系統(tǒng)轉(zhuǎn)為物理像素烘嘱。
所以說(shuō)昆禽,物理像素和設(shè)備獨(dú)立像素之間存在著一定的對(duì)應(yīng)關(guān)系,這就是設(shè)備像素比蝇庭。

設(shè)備像素比(device pixel ratio )

設(shè)備像素比(簡(jiǎn)稱dpr)定義了物理像素和設(shè)備獨(dú)立像素的對(duì)應(yīng)關(guān)系醉鳖,它的值可以按如下的公式的得到:

設(shè)備像素比 = 物理像素 / 設(shè)備獨(dú)立像素 // 在某一方向上,x方向或者y方向

在javascript中哮内,可以通過(guò)window.devicePixelRatio獲取到當(dāng)前設(shè)備的dpr盗棵。
在css中,可以通過(guò)-webkit-device-pixel-ratio-webkit-min-device-pixel-ratio-webkit-max-device-pixel-ratio進(jìn)行媒體查詢纹因,對(duì)不同dpr的設(shè)備喷屋,做一些樣式適配(這里只針對(duì)webkit內(nèi)核的瀏覽器和webview)。

viewport/視口

通俗的講瞭恰,移動(dòng)設(shè)備上的viewport就是設(shè)備的屏幕上能用來(lái)顯示我們的網(wǎng)頁(yè)的那一塊區(qū)域[1]逼蒙,但不一定是我們可見(jiàn)的區(qū)域。
在默認(rèn)情況下寄疏,一般來(lái)講是牢,移動(dòng)設(shè)備上的viewport都是要大于瀏覽器可視區(qū)域的,這是因?yàn)榭紤]到移動(dòng)設(shè)備的分辨率相對(duì)于桌面電腦來(lái)說(shuō)都比較小陕截,所以為了能在移動(dòng)設(shè)備上正常顯示那些傳統(tǒng)的為桌面瀏覽器設(shè)計(jì)的網(wǎng)站驳棱,移動(dòng)設(shè)備上的瀏覽器都會(huì)把自己默認(rèn)的viewport設(shè)為980px或1024px(也可能是其它值,這個(gè)是由設(shè)備自己決定的)农曲,但帶來(lái)的后果就是瀏覽器會(huì)出現(xiàn)橫向滾動(dòng)條社搅,因?yàn)闉g覽器可視區(qū)域的寬度是比這個(gè)默認(rèn)的viewport的寬度要小的。

關(guān)于三個(gè)viewport的理論

  • Visual Viewport

Visual Viewport: 可見(jiàn)視口乳规。就是移動(dòng)設(shè)備上可以被我們看見(jiàn)的部分形葬。寬度在移動(dòng)端通過(guò)window.innerWidth獲得(僅限移動(dòng)端,PC上哪怕是chrome模擬也會(huì)有不同的結(jié)果)暮的。

  • Layout Viewport

如果把移動(dòng)設(shè)備上瀏覽器的可視區(qū)域設(shè)為viewport的話笙以,某些網(wǎng)站就會(huì)因?yàn)関iewport太窄而顯示錯(cuò)亂,所以這些瀏覽器就決定默認(rèn)情況下把viewport設(shè)為一個(gè)較寬的值冻辩,比如980px猖腕,這樣的話即使是那些為桌面設(shè)計(jì)的網(wǎng)站也能在移動(dòng)瀏覽器上正常顯示了。寬度可以通過(guò)document.documentelement.clientWidth來(lái)獲取恨闪。

  • 理想視口/Ideal Viewport

Ideal Viewport:理想視口倘感,其實(shí)就是設(shè)備的可見(jiàn)區(qū)域,和可見(jiàn)視口一致咙咽。
設(shè)置Ideal Viewport的好處是老玛,只要按照Ideal Viewport來(lái)設(shè)計(jì)樣式稿,用戶就能不用左右滑動(dòng)和放大縮小來(lái)查看網(wǎng)站钧敞。

移動(dòng)設(shè)備默認(rèn)的viewport是layout viewport蜡豹,但在進(jìn)行移動(dòng)設(shè)備網(wǎng)站的開(kāi)發(fā)時(shí),我們需要的是ideal viewport犁享。
設(shè)置理想視口:

<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">

這段代碼的意思是將布局視口的寬度設(shè)置為設(shè)備寬度余素,初始縮放比例為1,最大縮放比例為1炊昆,用戶不能縮放桨吊。
其中設(shè)置<meta name="viewport" content="width=device-width"><meta name="viewport" content="initial-scale=1">效果一樣威根,即把當(dāng)前的viewport寬度變成ideal viewport的寬度。
如果width 和 initial-scale=1同時(shí)出現(xiàn)视乐,并且還出現(xiàn)了沖突洛搀,以哪個(gè)為準(zhǔn)呢?比如:

<meta name="viewport" content="width=400, initial-scale=1">

width=400表示把當(dāng)前viewport的寬度設(shè)為400px佑淀,initial-scale=1則表示把當(dāng)前viewport的寬度設(shè)為ideal viewport的寬度留美,那么瀏覽器到底該服從哪個(gè)命令呢?是書(shū)寫(xiě)順序在后面的那個(gè)嗎伸刃?不是谎砾。當(dāng)遇到這種情況時(shí),瀏覽器會(huì)取它們兩個(gè)中較大的那個(gè)值捧颅。例如景图,當(dāng)width=400,ideal viewport的寬度為320時(shí)碉哑,取的是400挚币;當(dāng)width=400, ideal viewport的寬度為480時(shí)扣典,取的是ideal viewport的寬度妆毕。

解決問(wèn)題

  • 圖片高清問(wèn)題

兩倍圖片(@2x),容器縮小50%贮尖;

  • border: 1px問(wèn)題

.scale{
    position: relative;
}
.scale:after{
    content:"";
    position: absolute;
    bottom:0px;
    left:0px;
    right:0px;
    border-bottom:1px solid #ddd;
    -webkit-transform:scaleY(.5);
    -webkit-transform-origin:0 0;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末笛粘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子远舅,更是在濱河造成了極大的恐慌闰蛔,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,744評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件图柏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡任连,警方通過(guò)查閱死者的電腦和手機(jī)蚤吹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)随抠,“玉大人裁着,你說(shuō)我怎么就攤上這事」八” “怎么了二驰?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,105評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)秉沼。 經(jīng)常有香客問(wèn)我桶雀,道長(zhǎng)矿酵,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,242評(píng)論 1 292
  • 正文 為了忘掉前任矗积,我火速辦了婚禮全肮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘棘捣。我一直安慰自己辜腺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評(píng)論 6 389
  • 文/花漫 我一把揭開(kāi)白布乍恐。 她就那樣靜靜地躺著评疗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪茵烈。 梳的紋絲不亂的頭發(fā)上壤巷,一...
    開(kāi)封第一講書(shū)人閱讀 51,215評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音瞧毙,去河邊找鬼胧华。 笑死,一個(gè)胖子當(dāng)著我的面吹牛宙彪,可吹牛的內(nèi)容都是我干的矩动。 我是一名探鬼主播,決...
    沈念sama閱讀 40,096評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼释漆,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼悲没!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起男图,我...
    開(kāi)封第一講書(shū)人閱讀 38,939評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤示姿,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后逊笆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體栈戳,經(jīng)...
    沈念sama閱讀 45,354評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評(píng)論 2 333
  • 正文 我和宋清朗相戀三年难裆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了子檀。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,745評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乃戈,死狀恐怖褂痰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情症虑,我是刑警寧澤缩歪,帶...
    沈念sama閱讀 35,448評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站谍憔,受9級(jí)特大地震影響匪蝙,放射性物質(zhì)發(fā)生泄漏主籍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評(píng)論 3 327
  • 文/蒙蒙 一骗污、第九天 我趴在偏房一處隱蔽的房頂上張望崇猫。 院中可真熱鬧,春花似錦需忿、人聲如沸诅炉。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,683評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)涕烧。三九已至,卻和暖如春汗洒,著一層夾襖步出監(jiān)牢的瞬間议纯,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,838評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工溢谤, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瞻凤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,776評(píng)論 2 369
  • 正文 我出身青樓世杀,卻偏偏與公主長(zhǎng)得像阀参,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瞻坝,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容