天天看點

css3 media響應式媒體查詢器用法總結

    随着響應式設計模型的誕生,Web網站又要發生翻天腹地的改革浪潮,可能有些人會覺得在國内IE6使用者居高不下的情況下,這些新的技術還不會廣泛的蔓延下去,那你就錯了,如今淘寶,凡客,攜程等等公司都已經在大膽的嘗試了這項技術,并完美的應用在了自己的網站上了。再不更新知識你就老了

css3 media響應式媒體查詢器用法總結

。我今天就總結一下響應式設計的核心CSS技術Media(媒體查詢器)的用法。

準備工作1:設定Meta标簽

首先我們在使用Media的時候需要先設定下面這段代碼,來相容移動裝置的展示效果:

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

這段代碼的幾個參數解釋:

  • width = device-width:寬度等于目前裝置的寬度
  • initial-scale:初始的縮放比例(預設設定為1.0)  
  • minimum-scale:允許使用者縮放到的最小比例(預設設定為1.0)    
  • maximum-scale:允許使用者縮放到的最大比例(預設設定為1.0)   
  • user-scalable:使用者是否可以手動縮放(預設設定為no,因為我們不希望使用者放大縮小頁面) 

準備工作2:加載相容檔案JS

因為IE8既不支援HTML5也不支援CSS3 Media,是以我們需要加載兩個JS檔案,來保證我們的代碼實作相容效果:

  1. <!--[if lt IE 9]>
  2.   <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
  3.   <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
  4. <![endif]-->

準備工作3:設定IE渲染方式預設為最高(這部分可以選擇添加也可以不添加)

現在有很多人的IE浏覽器都更新到IE9以上了,是以這個時候就有又很多詭異的事情發生了,例如現在是IE9的浏覽器,但是浏覽器的文檔模式卻是IE8:

css3 media響應式媒體查詢器用法總結

為了防止這種情況,我們需要下面這段代碼來讓IE的文檔模式永遠都是最新的:

  1. <meta http-equiv="X-UA-Compatible" content="IE=edge">
css3 media響應式媒體查詢器用法總結

太給力了。

不過我最近又發現了一個更給力的寫法:

  1. <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">

怎麼這段代碼後面加了一個chrome=1,這個Google Chrome Frame(谷歌内嵌浏覽器架構GCF),如果有的使用者電腦裡面裝了這個chrome的插件,就可以讓電腦裡面的IE不管是哪個版本的都可以使用Webkit引擎及V8引擎進行排版及運算,無比給力,不過如果使用者沒裝這個插件,那這段代碼就會讓IE以最高的文檔模式展現效果。這段代碼我還是建議你們用上,不過不用也是可以的。

進入CSS3 Media寫法

我們先來看下下面這段代碼,估計很多人在響應式的網站CSS很經常看到類似下面的這段代碼:

  1. @media screen and (max-width: 960px){
  2.     body{
  3.         background: #000;
  4.     }
  5. }

這個應該算是一個media的一個标準寫法,上面這段CSS代碼意思是:當頁面小于960px的時候執行它下面的CSS.這個應該沒有太大疑問。

應該有人會發現上面這段代碼裡面有個screen,他的意思是在告知裝置在列印頁面時使用襯線字型,在螢幕上顯示時用無襯線字型。但是目前我發現很多網站都會直接省略screen,因為你的網站可能不需要考慮使用者去列印時,你可以直接這樣寫:

  1. @media (max-width: 960px){
  2.     body{
  3.         background: #000;
  4.     }
  5. }

CSS2 Media用法

其實并不是隻有CSS3才支援Media的用法,早在CSS2開始就已經支援Media,具體用法,就是在HTML頁面的head标簽中插入如下的一段代碼:

  1. <link rel="stylesheet" type="text/css" media="screen" href="style.css" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >

上面其實是CSS2實作的襯線用法,那CSS3的media難道就隻能支援上面這一個功能嗎?答案當然不是,他還有很多用法。

例如我們想知道現在的移動裝置是不是縱向放置的顯示屏,可以這樣寫:

  1. <link rel="stylesheet" type="text/css" media="screen and (orientation:portrait)" href="style.css" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >

我們把第一段的代碼也用CSS2來實作,讓它一樣可以讓頁面寬度小于960的執行指定的樣式檔案:

  1. <link rel="stylesheet" type="text/css" media="screen and (max-width:960px)" href="style.css" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >

既然CSS2可以實作CSS的這個效果為什麼不用這個方法呢,很多人應該會問,但是上面這個方法,最大的弊端是他會增加頁面http的請求次數,增加了頁面負擔,我們用CSS3把樣式都寫在一個檔案裡面才是最佳的方法。

回歸CSS3 Media

上面我們大概講了下CSS2的媒體查詢用法,現在我們重新回到CSS3的媒體查詢,在第一段代碼上面我用的是小于960px的尺寸的寫法,那現在我們來實作等于960px尺寸的代碼:

  1. @media screen and (max-device-width:960px){
  2.     body{
  3.         background:red;
  4.     }
  5. }

然後就是當浏覽器尺寸大于960px時候的代碼了:

  1. @media screen and (min-width:960px){
  2.     body{
  3.         background:orange;
  4.     }
  5. }

我們還可以混合使用上面的用法:

  1. @media screen and (min-width:960px) and (max-width:1200px){
  2.     body{
  3.         background:yellow;
  4.     }
  5. }

上面的這段代碼的意思是當頁面寬度大于960px小于1200px的時候執行下面的CSS。

Media所有參數彙總

以上就是我們最常需要用到的媒體查詢器的三個特性,大于,等于,小于的寫法。媒體查詢器的全部功能肯定不止這三個功能,下面是我總結的它的一些參數用法解釋:

  • width:浏覽器可視寬度。
  • height:浏覽器可視高度。
  • device-width:裝置螢幕的寬度。
  • device-height:裝置螢幕的高度。
  • orientation:檢測裝置目前處于橫向還是縱向狀态。
  • aspect-ratio:檢測浏覽器可視寬度和高度的比例。(例如:aspect-ratio:16/9)
  • device-aspect-ratio:檢測裝置的寬度和高度的比例。
  • color:檢測顔色的位數。(例如:min-color:32就會檢測裝置是否擁有32位顔色)
  • color-index:檢查裝置顔色索引表中的顔色,他的值不能是負數。
  • monochrome:檢測單色楨緩沖區域中的每個像素的位數。(這個太進階,估計咱很少會用的到)
  • resolution:檢測螢幕或列印機的分辨率。(例如:min-resolution:300dpi或min-resolution:118dpcm)。
  • grid:檢測輸出的裝置是網格的還是位圖裝置。