自适应设计与响应式设计
目前非常流行自適應(yīng)設(shè)計(jì)與響應(yīng)式設(shè)計(jì),而且經(jīng)常讓人混淆,自適應(yīng)設(shè)計(jì)不應(yīng)與自適應(yīng)布局混為一談,它們是完全不一樣的概念。
在這先說(shuō)明下這兩者的異同:
自從移動(dòng)終端飛速發(fā)展以來(lái),各種各樣的機(jī)型突飛猛進(jìn),很多網(wǎng)站的解決方法,是為不同的設(shè)備提供不同的網(wǎng)頁(yè),比如專門提供一個(gè)mobile版本,或者iPhone/iPad版本。這樣做固然保證了效果,但是比較麻煩,同時(shí)要維護(hù)好幾個(gè)版本,而且如果一個(gè)網(wǎng)站有多個(gè)portal(入口),會(huì)大大增加架構(gòu)設(shè)計(jì)的復(fù)雜度。
于是,很早就有人設(shè)想,能不能"一次設(shè)計(jì),普遍適用",讓同一張網(wǎng)頁(yè)自動(dòng)適應(yīng)不同大小的屏幕,根據(jù)屏幕寬度,自動(dòng)調(diào)整布局(layout)?
2010年,Ethan?Marcotte提出了"自適應(yīng)網(wǎng)頁(yè)設(shè)計(jì)"(Responsive?Web?Design)這個(gè)名詞,指可以自動(dòng)識(shí)別屏幕寬度、并做出相應(yīng)調(diào)整的網(wǎng)頁(yè)設(shè)計(jì)。
?
圖片來(lái)源http://mashable.com/2012/12/11/responsive-web-design/
如圖所示就叫做自適應(yīng)布局。自適應(yīng)布局有它的使用價(jià)值,在于它能夠提供一種更加實(shí)用的解決方案,使得項(xiàng)目的實(shí)現(xiàn)成本更低,并且更加易于測(cè)試。一個(gè)自適應(yīng)布局可以被看作是響應(yīng)式布局的一個(gè)更加廉價(jià)的替代品,會(huì)在項(xiàng)目資源緊缺的情況下更具有吸引力。
而在響應(yīng)式布局中你卻要考慮上百種不同的狀態(tài):
響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)是自適應(yīng)網(wǎng)頁(yè)設(shè)計(jì)的子集。響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)指的是頁(yè)面的布局(流動(dòng)網(wǎng)格、靈活的圖像及媒介查詢)。總體目標(biāo)就是去解決設(shè)備多樣化問題。
響應(yīng)式布局等于流動(dòng)網(wǎng)格布局,而自適應(yīng)布局等于使用固定分割點(diǎn)來(lái)進(jìn)行布局。
當(dāng)固定寬度與流動(dòng)寬度結(jié)合起來(lái)時(shí),自適應(yīng)布局就是一種響應(yīng)式設(shè)計(jì),而不僅僅是它的一種替代方法。?
那么如何進(jìn)行響應(yīng)式布局呢?下面就一步步為你揭開響應(yīng)式布局的面紗:
Skill 1?學(xué)會(huì)運(yùn)用?Css3?Media?Queries,根據(jù)不同的屏幕分辨率,選擇應(yīng)用不同的Css規(guī)則
Media?Queries語(yǔ)法簡(jiǎn)介:
max-width:若瀏覽區(qū)域的寬度小于400像素,則下方的CSS描述就會(huì)立即被套用:
| 12345 | @media screen and (max-width:400px){ ????.class??{???????? background:#ccc; ???? } } | 
也可以把要套用的描述獨(dú)立成外部檔案:
| 1 | <link rel="stylesheet" media="screen and (max-width: 400px)" href="mini.css" /> | 
Min?Width:若瀏覽區(qū)域的寬度大于800像素,則下方的CSS描述就會(huì)立即被套用:
| 123456 | @media screen and (min-width:800px){??.class??{????background:#666;??}} | 
Device?Width:若瀏覽設(shè)備的可視范圍最大為480px,則下方的CSS描述就會(huì)立即被套用:(注:移動(dòng)手機(jī)目前常見最大寬度為480px,如iPhone?or?Android?Phone)
| 123456 | @media screen and (max-device-width:480px){??.class??{????background:#000;??}} | 
針對(duì)iPhone4提供專用的css設(shè)定檔:
| 1 | <link rel= "stylesheet"??media= "only screen and (-webkit-min-device-pixel-ratio: 2)"??type= "text/css"??href= "iphone4.css"??/> | 
針對(duì)iPad的Portrait?Mode(直立)與Landscape?Mode(橫躺)兩種瀏覽模式給予不同的css設(shè)定檔:
| 123 | <link rel="stylesheet" media="all and (orientation:portrait)" href="portrait.css"><link rel="stylesheet" media="all and (orientation:landscape)" href="landscape.css"> | 
Skill?2?在網(wǎng)頁(yè)頭部加上viewport標(biāo)簽
| 1 | <meta name="viewport" content="width=device-width, initial-scale=1.0"> | 
瀏覽器推出了“viewport?meta”標(biāo)簽,許多移動(dòng)瀏覽器現(xiàn)在都支持這個(gè)標(biāo)簽,W3C?協(xié)議定義?viewport?meta?目前還屬于草案,很多人都會(huì)在html?head?處加上?viewport?這個(gè)meta?data,一個(gè)典型的移動(dòng)端viewport如下所示:
| 1 | <meta name="viewport" content="width=device-width, initial-scale=1.0"> | 
該屬性可以控制視窗口寬度的大小。它可以被設(shè)置為實(shí)際的具體像素width=?600或?yàn)樘厥庠O(shè)備設(shè)置寬度值。
viewport設(shè)置屬性如下:
width:可設(shè)定數(shù)值,或者指定為?device-width
height:可設(shè)定數(shù)值,或者指定為?device-height
initial-scale:第一次進(jìn)入頁(yè)面的初始比例
minimum-scale:允許縮小最小比例
maximum-scale:允許放大最大比例
user-scalable:允許使用者縮放,1?or?0?(yes?or?no)
編譯過程會(huì)轉(zhuǎn)化成如下的語(yǔ)義:
| 1234567 | @viewport {????width: device-width;????initial-scale: 1.0} | 
device-width?,主要是為了讓整個(gè)頁(yè)面寬度與手機(jī)可視寬度相同,這樣就可以簡(jiǎn)單相容于不同機(jī)型屏幕大小,如果這邊width沒有設(shè)定的話,就會(huì)依照html/css給予的width當(dāng)作預(yù)設(shè)值。
因?yàn)榻馕龆炔煌?#xff0c;device-width有時(shí)候不一定是view?width,所以在類似iphone?4高解析度機(jī)器上,device-width=320?,可是實(shí)際解析度為480,這時(shí)候就需要利用javascript針對(duì)UA下去做動(dòng)態(tài)調(diào)整。
user-scalable,這個(gè)屬性可以讓使用者能否放大、縮小頁(yè)面,如果頁(yè)面不允許手機(jī)使用者縮放,就直接設(shè)定0或者no,反之要啟動(dòng)縮放功能,就設(shè)置1或者是yes。
接下來(lái)將說(shuō)明幾種常用的方式,以及具體例子提供給大家參考。
如果在手機(jī)端我們希望網(wǎng)頁(yè)呈現(xiàn)固定,不希望使用者隨意縮放,直接設(shè)定如下
| 1 | <meta name="viewport" content="width=device-width, initial-scale=1.0"> | 
如果希望在不同device使用不同縮放大小,就必須使用javascript,檢測(cè)UA(User?agent),動(dòng)態(tài)設(shè)定viewport,如下:
| 12 | viewport = document.querySelector("meta[name=viewport]");viewport.setAttribute('content', 'width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=0;'); | 
Skill?3 不使用絕對(duì)寬度
由于網(wǎng)頁(yè)會(huì)根據(jù)屏幕寬度調(diào)整布局,所以不能使用絕對(duì)寬度(margin-left:5px)的布局,也不能使用具有絕對(duì)寬度(例如:width:200px)的元素,而最好使用百分比寬度width:20%;或者with:auto;
Skill?4 字體最好不要用絕對(duì)大小(px),而使用相對(duì)大小(em)
| 1 | body { font: normal 100% Helvetica, Arial, sans-serif; } | 
上面的代碼指定,字體大小是頁(yè)面默認(rèn)大小的100%,即16像素。
| 1 | h1 { font-size: 1.5em; }?? | 
h1的大小是默認(rèn)大小的1.5倍,即24像素(24/16=1.5)
| 1 | .small { font-size: 0.875em; } | 
small元素的大小是默認(rèn)大小的0.875倍,即14像素(14/16=0.875)
?這里順便說(shuō)說(shuō)?px??pt?em ?rem區(qū)別:
px是pixel,像素,是屏幕上顯示數(shù)據(jù)的最基本的點(diǎn),在HTML中,默認(rèn)的單位就是px;
pt是point,是印刷行業(yè)常用單位,等于1/72英寸。
em才是真正的“相對(duì)單位”(百分比嘛,當(dāng)然是相對(duì)),而px和pt都是絕對(duì)單位(都有固定值)。所以,一般移動(dòng)終端布局用em比較合適。
rem是css3的出現(xiàn),同時(shí)引進(jìn)新的單位,而rem是相對(duì)于根元素<html>,這樣就意味著,我們只需要在根元素確定一個(gè)參考值,在根元素中設(shè)置多大的字體,這完全可以根據(jù)您自己的需要。
Skill?5?流動(dòng)布局(fluid?grid)
流動(dòng)布局的含義是各個(gè)位置都是浮動(dòng)的,不是固定不變的
| 123 | .main { float: right; width: 70%; } .leftBar { float: left; width: 25%; } | 
float的好處是,如果寬度太小,放不下兩個(gè)元素,后面的元素會(huì)自動(dòng)滾動(dòng)到前面元素的下方,不會(huì)在水平方向overflow(溢出),避免了水平滾動(dòng)條的出現(xiàn)。
Skill?6 圖片的自動(dòng)縮放,等比縮放
| 12345 | img{????max-width: 100%; } | 
要使圖片按等比縮放,一般不需要規(guī)定圖片高度。且最好不用background-image,因?yàn)檫@樣不會(huì)按照等比縮放。
最后請(qǐng)欣賞基于Media Queries的響應(yīng)式布局優(yōu)秀案例,請(qǐng)手機(jī)掃一掃:
??
上訴網(wǎng)頁(yè)你可以用瀏覽器和手機(jī)打開瀏覽。發(fā)現(xiàn)在PC和移動(dòng)端顯示有很大變化。簡(jiǎn)單說(shuō)呢就針對(duì)不同的屏幕分辨率應(yīng)用不同的CSS樣式。
轉(zhuǎn)載自AlloyTeam:http://www.alloyteam.com/2015/04/zi-shi-ying-she-ji-yu-xiang-ying-shi-wang-ye-she-ji-qian-tan/
轉(zhuǎn)載于:https://www.cnblogs.com/jill1231/p/5218264.html
總結(jié)
以上是生活随笔為你收集整理的自适应设计与响应式设计的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: Robotium双client測试框架
- 下一篇: call()和apply()方法(切换上
