css響應式布局


“自適應網頁設計”到底是怎么做到的?其實並不難。

一、viewport

首先,在網頁代碼的頭部,加入一行viewport元標簽

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

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

二、流動布局(fluid grid)

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

.main{float: right;width: 70%; height:300px ;background-color: azure}
.leftBar{float: left;width: 25%; height:300px; background-color: burlywood}

float的好處是,如果寬度太小,放不下兩個元素,后面的元素會自動滾動到前面元素的下方,不會在水平方向overflow(溢出),避免了水平滾動條的出現。(這里使用了百分比,不會出現這個情況,但如果width固定就會出現)

.main{float: right;width: 700px; height:300px ;background-color: azure}
.leftBar{float: left;width: 250px; height:300px; background-color: burlywood}

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

三、媒體監聽

選擇加載CSS

“自適應網頁設計”的核心,就是CSS3引入的Media Query模塊。
它的意思就是,自動探測屏幕寬度,然后加載相應的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文件。

除了用html標簽加載CSS文件,還可以在現有CSS文件中加載。
@import url("tinyScreen.css") screen and (max-device-width: 400px);

CSS的@media規則

同一個CSS文件中,也可以根據不同的屏幕分辨率,選擇應用不同的CSS規則。

@media screen and (max-device-width: 400px) 
{
  .column {float: none;width: auto;} 
  #sidebar {display: none}
}

上面的代碼意思是,如果屏幕寬度小於400像素,則column塊取消浮動(float:none)、寬度自動調節(width:auto),sidebar塊不顯示(display:none)。

示例如下

<style type="text/css">
  /*屏幕寬度大於900的時候*/
  *
  {
      padding:0px;
      margin:0px;
      font-family:"微軟雅黑";
  }
  #header
  {
      height:100px;
      border:solid 1px red;
      margin:0px auto;
  }
  #main
  {
      margin:10px auto;
      height:400px;
  }
  #footer
  {
      margin:0px auto;
      height:100px;
      border:solid 1px red;
  }
  @media screen and (min-width:900px)
  {
      #header,#footer
      {
          width:800px;
      }
      #main
      {
          width:800px;
          height:400px;;
      }
      #main-left
      {
          width:200px;
          height:400px;
          border:solid 1px red;
          float:left;
      }
      #main-center
      {
          width:394px;
          height:400px;
          border:solid 1px red;
          float:left;
      }
      #main-right
      {
          width:200px;
          height:400px;
          border:solid 1px red;
          float:left;
      }
  }
  @media screen and (min-width:600px) and (max-width:900px)
  {
      #header,#footer
      {
          width:600px;
      }
      #main
      {
          width:600px;
          height:400px;;
      }
      #main-left
      {
          width:200px;
          height:400px;
          border:solid 1px red;
          float:left;
      }
      #main-center
      {
          width:396px;
          height:400px;
          border:solid 1px red;
          float:left;
      }
      #main-right
      {
          display:none;
      }
  }
  @media screen and (max-width:600px)
  {
      #header,#footer
      {
          width:300px;
      }
      #main
      {
          width:300px;
          height:400px;;
      }
      #main-left
      {
          display:none;
      }
      #main-center
      {
          width:300px;
          height:400px;
          border:solid 1px red;
      }
      #main-right
      {
          display:none;
      }
  }
  </style>
  </head>
  <body>
  <div id="header">頭部</div>
  <div id="main">
    <div id="main-left">主題-左邊</div>
    <div id="main-center">主題-中間</div>
    <div id="main-right">主題-右邊</div>
  </div>
  <div id="footer"></div>
  </body>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM