1. 程式人生 > >HTML頁面適配手機移動端視窗寬度

HTML頁面適配手機移動端視窗寬度

         隨著網路的快熟發展,越來越多的人使用手機上網。移動裝置正超過桌面裝置,成為訪問網際網路的最常見終端。於是,網頁設計師不得不面對一個難題:如何才能在不同大小的裝置上呈現同樣的網頁?手機的螢幕比較小,寬度通常在600畫素以下;PC的螢幕寬度,一般都在1000畫素以上,有的還達到了2000畫素。同樣的內容,要在大小迥異的螢幕上,都呈現出滿意的效果,並不是一件容易的事。很多網站的做法是對不同終端設計多個網頁,但這樣會有很多維護的問題,在這裡我們可以設計一個簡單的盒子,這個盒子可以識別不同的終端而顯示不同的效果

  1. 在網頁程式碼的頭部,加入一行viewport元標籤。

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

    viewport是網頁預設的寬度和高度,上面這行程式碼的意思是,網頁寬度預設等於螢幕寬度(width=device-width),原始縮放比例(initial-scale=1)為1.0,即網頁初始大小佔螢幕面積的100%。

  2. 由於網頁會根據螢幕寬度調整佈局,所以不能使用絕對寬度的佈局,也不能使用具有絕對寬度的元素。對影象來說也是這樣。

    具體說,CSS程式碼不能指定畫素寬度:

    width:xxx px;

    只能指定百分比寬度:

    width: xx%;

    或者

    width:auto;

  3.  字型也不能使用絕對大小(px),而只能使用相對大小(em)。

    例如:

    body {font: normal 100% Helvetica, Arial,sans-serif;}

    上面的程式碼指定,字型大小是頁面預設大小的100%,即16畫素。

  4.  流動佈局(fluid grid)

    "流動佈局"的含義是,各個區塊的位置都是浮動的,不是固定不變的。

    .main {float: right;width: 70%; }

    .leftBar {float: left;width: 25%;}

    float的好處是,如果寬度太小,放不下兩個元素,後面的元素會自動滾動到前面元素的下方,不會在水平方向overflow(溢位),避免了水平滾動條的出現。

  5.  "自適應網頁設計"的核心,就是CSS3引入的MediaQuery模組。

    它的意思就是,自動探測螢幕寬度,然後載入相應的CSS檔案。

    <link rel="stylesheet" type="text/css"media="screen and (max-device-width:400px)"href="tinyScreen.css" />

    上面的程式碼意思是,如果螢幕寬度小於400畫素(max-device-width: 400px),就載入tinyScreen.css檔案。

    <link rel="stylesheet" type="text/css"media="screen and (min-width: 400px)and (max-device-width: 600px)"href="smallScreen.css" />

    如果螢幕寬度在400畫素到600畫素之間,則載入smallScreen.css檔案。