頁面自適應屏幕大小


手機的屏幕比較小灭衷,寬度通常在600像素以下;PC的屏幕寬度严嗜,一般都在1000像素以上(目前主流寬度是1366×768)粱檀,有的還達到了2000像素。同樣的內容漫玄,要在大小迥異的屏幕上茄蚯,都呈現(xiàn)出滿意的效果,并不是一件容易的事。

很多網(wǎng)站的解決方法渗常,是為不同的設備提供不同的網(wǎng)頁壮不,比如專門提供一個mobile版本,或者iPhone / iPad版本凳谦。這樣做固然保證了效果忆畅,但是比較麻煩衡未,同時要維護好幾個版本尸执,而且如果一個網(wǎng)站有多個portal(入口),會大大增加架構設計的復雜度缓醋。

于是如失,很早就有人設想,能不能”一次設計送粱,普遍適用”褪贵,讓同一張網(wǎng)頁自動適應不同大小的屏幕,根據(jù)屏幕寬度抗俄,自動調整布局(layout)脆丁?

一、”自適應網(wǎng)頁設計”的概念

2010年动雹,Ethan Marcotte提出了”自適應網(wǎng)頁設計”(Responsive Web Design)這個名詞槽卫,指可以自動識別屏幕寬度、并做出相應調整的網(wǎng)頁設計胰蝠。

他制作了一個范例歼培,里面是《福爾摩斯歷險記》六個主人公的頭像。如果屏幕寬度大于1300像素茸塞,則6張圖片并排在一行躲庄。

如果屏幕寬度在600像素到1300像素之間,則6張圖片分成兩行钾虐。

如果屏幕寬度在400像素到600像素之間噪窘,則導航欄移到網(wǎng)頁頭部。

如果屏幕寬度在400像素以下效扫,則6張圖片分成三行倔监。

mediaqueri.es上面有更多這樣的例子。

二荡短、允許網(wǎng)頁寬度自動調整

“自適應網(wǎng)頁設計”到底是怎么做到的丐枉?其實并不難。

首先掘托,在網(wǎng)頁代碼的頭部瘦锹,加入一行viewport元標簽

viewport是網(wǎng)頁默認的寬度和高度,上面這行代碼的意思是弯院,網(wǎng)頁寬度默認等于屏幕寬度(width=device-width)辱士,原始縮放比例(initial-scale=1)為1.0,即網(wǎng)頁初始大小占屏幕面積的100%听绳。

所有主流瀏覽器都支持這個設置颂碘,包括IE9。對于那些老式瀏覽器(主要是IE6椅挣、7头岔、8),需要使用css3-mediaqueries.js鼠证。

“自適應網(wǎng)頁設計”到底是怎么做到的峡竣?其實并不難。

首先量九,在網(wǎng)頁代碼的頭部适掰,加入一行viewport元標簽。

viewport是網(wǎng)頁默認的寬度和高度荠列,上面這行代碼的意思是类浪,網(wǎng)頁寬度默認等于屏幕寬度(width=device-width),原始縮放比例(initial-scale=1)為1.0肌似,即網(wǎng)頁初始大小占屏幕面積的100%费就。

所有主流瀏覽器都支持這個設置,包括IE9锈嫩。對于那些老式瀏覽器(主要是IE6受楼、7、8)呼寸,需要使用css3-mediaqueries.js艳汽。


三、不使用絕對寬度

由于網(wǎng)頁會根據(jù)屏幕寬度調整布局对雪,所以不能使用絕對寬度的布局河狐,也不能使用具有絕對寬度的元素。這一條非常重要瑟捣。

具體說馋艺,CSS代碼不能指定像素寬度:

width:300px;

只能指定百分比寬度:

width:??98%;

或者

width:auto;

四、相對大小的字體

字體也不能使用絕對大新跆住(px)捐祠,而只能使用相對大小(em)桑李。

 body?{

    font:?normal?100%?Helvetica,?Arial,?sans-serif;

 }

上面的代碼指定踱蛀,字體大小是頁面默認大小的100%窿给,即16像素。

h1?{

  font-size:?1.5em;

}

然后率拒,h1的大小是默認大小的1.5倍崩泡,即24像素(24/16=1.5)。

  small?{

    font-size:?0.875em;

  }

small元素的大小是默認大小的0.875倍猬膨,即14像素(14/16=0.875)角撞。

五、流動布局(fluid?grid)

“流動布局”的含義是勃痴,各個區(qū)塊的位置都是浮動的谒所,不是固定不變的。

.main?{

????float:?right;

????width:?70%;

}

.leftBar?{

????float:?left;

????width:?25%;

}

float的好處是召耘,如果寬度太小百炬,放不下兩個元素,后面的元素會自動滾動到前面元素的下方污它,不會在水平方向overflow(溢出),避免了水平滾動條的出現(xiàn)庶弃。

另外衫贬,絕對定位(position:?absolute)的使用,也要非常小心歇攻。

六固惯、選擇加載CSS

“自適應網(wǎng)頁設計”的核心,就是CSS3引入的Media?Query模塊缴守。

它的意思就是葬毫,自動探測屏幕寬度,然后加載相應的CSS文件屡穗。

上面的代碼意思是贴捡,如果屏幕寬度小于400像素(max-device-width:?400px),就加載tinyScreen.css文件村砂。

    media=”screen?and?(min-width:?400px)?and?(max-device-width:?600px)”

    href=”smallScreen.css”?/>

如果屏幕寬度在400像素到600像素之間烂斋,則加載smallScreen.css文件。

除了用html標簽加載CSS文件础废,還可以在現(xiàn)有CSS文件中加載汛骂。

@import?url(“tinyScreen.css”)?screen?and?(max-device-width:?400px);

七、CSS的@media規(guī)則

同一個CSS文件中评腺,也可以根據(jù)不同的屏幕分辨率帘瞭,選擇應用不同的CSS規(guī)則。

@media?screen?and?(max-device-width:?400px)?{

  .column?{

    float:?none;

    width:auto;

  }

  #sidebar?{

    display:none;

  }

}

上面的代碼意思是蒿讥,如果屏幕寬度小于400像素蝶念,則column塊取消浮動(float:none)锋拖、寬度自動調節(jié)(width:auto),sidebar塊不顯示(display:none)祸轮。

八兽埃、圖片的自適應(fluid?image)

除了布局和文本,”自適應網(wǎng)頁設計”還必須實現(xiàn)圖片的自動縮放适袜。

這只要一行CSS代碼:

img?{?max-width:?100%;}

這行代碼對于大多數(shù)嵌入網(wǎng)頁的視頻也有效柄错,所以可以寫成:

img,?object?{?max-width:?100%;}

老版本的IE不支持max-width,所以只好寫成:

img?{?width:?100%;?}

此外苦酱,windows平臺縮放圖片時售貌,可能出現(xiàn)圖像失真現(xiàn)象。這時疫萤,可以嘗試使用IE的專有命令:

img?{?-ms-interpolation-mode:?bicubic;?}

或者颂跨,Ethan?Marcotte的imgSizer.js。

addLoadEvent(function()?{

  var?imgs?=?document.getElementByIdx_x_x(“content”).getElementsByTagName_r(“img”);

  imgSizer.collate(imgs);

});

不過扯饶,有條件的話恒削,最好還是根據(jù)不同大小的屏幕,加載不同分辨率的圖片尾序。有很多方法可以做到這一條钓丰,服務器端和客戶端都可以實現(xiàn)。

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末每币,一起剝皮案震驚了整個濱河市携丁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌兰怠,老刑警劉巖梦鉴,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異揭保,居然都是意外死亡肥橙,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進店門掖举,熙熙樓的掌柜王于貴愁眉苦臉地迎上來快骗,“玉大人,你說我怎么就攤上這事塔次》嚼海” “怎么了?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵励负,是天一觀的道長藕溅。 經(jīng)常有香客問我,道長继榆,這世上最難降的妖魔是什么巾表? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任汁掠,我火速辦了婚禮,結果婚禮上集币,老公的妹妹穿的比我還像新娘考阱。我一直安慰自己,他們只是感情好鞠苟,可當我...
    茶點故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布乞榨。 她就那樣靜靜地躺著,像睡著了一般当娱。 火紅的嫁衣襯著肌膚如雪吃既。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天跨细,我揣著相機與錄音鹦倚,去河邊找鬼。 笑死冀惭,一個胖子當著我的面吹牛震叙,可吹牛的內容都是我干的。 我是一名探鬼主播云头,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼捐友,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了溃槐?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤科吭,失蹤者是張志新(化名)和其女友劉穎昏滴,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體对人,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡谣殊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了牺弄。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片姻几。...
    茶點故事閱讀 40,852評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖势告,靈堂內的尸體忽然破棺而出蛇捌,到底是詐尸還是另有隱情,我是刑警寧澤咱台,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布络拌,位于F島的核電站,受9級特大地震影響回溺,放射性物質發(fā)生泄漏春贸。R本人自食惡果不足惜混萝,卻給世界環(huán)境...
    茶點故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望萍恕。 院中可真熱鬧逸嘀,春花似錦、人聲如沸允粤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽维哈。三九已至绳姨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間阔挠,已是汗流浹背飘庄。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留购撼,地道東北人跪削。 一個月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像迂求,于是被迫代替她去往敵國和親碾盐。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,851評論 2 361

推薦閱讀更多精彩內容