CSS3 @media screen 屏幕自適應(yīng)

優(yōu)點(diǎn):

無(wú)需插件和手機(jī)主題,對(duì)移動(dòng)設(shè)備友好,能夠適應(yīng)各種窗口大小。只需在CSS中添加@media screen屬性,根據(jù)瀏覽器寬度判斷并輸出不同的長(zhǎng)寬值。

準(zhǔn)備工作1:設(shè)置Meta標(biāo)簽

首先,在使用Media時(shí),需要先設(shè)置下面這段代碼,來(lái)兼容移動(dòng)設(shè)備的展示效果:

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

這段代碼的幾個(gè)參數(shù)解釋:

width = device-width:寬度等于當(dāng)前設(shè)備的寬度
height = device-height:高度等于當(dāng)前設(shè)備的高度
initial-scale:初始的縮放比例(默認(rèn)設(shè)置為1.0)  
minimum-scale:允許用戶縮放到的最小比例(默認(rèn)設(shè)置為1.0)    
maximum-scale:允許用戶縮放到的最大比例(默認(rèn)設(shè)置為1.0)   
user-scalable:用戶是否可以手動(dòng)縮放(默認(rèn)設(shè)置為no,因?yàn)槲覀儾幌M脩舴糯罂s小頁(yè)面)

準(zhǔn)備工作2:加載兼容JS文件

因?yàn)镮E8既不支持HTML5也不支持CSS3 Media,所以需要加載兩個(gè)JS文件,來(lái)保證代碼實(shí)現(xiàn)兼容效果:

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

準(zhǔn)備工作3:設(shè)置IE渲染方式默認(rèn)為最高(這部分可以選擇添加也可以不添加)

現(xiàn)在很多人的IE瀏覽器都升級(jí)到IE9以上了,這時(shí)候有很多詭異的事情發(fā)生了,例如現(xiàn)在是IE9的瀏覽器,但是瀏覽器的文檔模式卻是IE8。為了防止這種情況,需要用下面這段代碼來(lái)讓IE的文檔模式永遠(yuǎn)都是最新的:

<meta http-equiv="X-UA-Compatible" content="IE=edge">

如果想使用固定的IE版本,可寫成:

<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE9">

或者也可以這樣寫:

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

怎么這段代碼后面加了一個(gè)chrome=1?
如果用戶電腦里裝了Google Chrome Frame(谷歌內(nèi)嵌瀏覽器框架GCF)這個(gè)chrome插件,就可以讓電腦里面的IE不管是哪個(gè)版本的都可以使用Webkit引擎及V8引擎進(jìn)行排版及運(yùn)算;如果用戶沒(méi)裝這個(gè)插件,那這段代碼就會(huì)讓IE以最高的文檔模式展現(xiàn)效果。
這段代碼建議用上,不過(guò)不用也是可以的。

進(jìn)入CSS3 Media寫法

先來(lái)看看下面這段代碼,估計(jì)很多人在響應(yīng)式網(wǎng)站的CSS中經(jīng)??吹筋愃葡旅娴倪@段代碼:

@media screen and (max-width: 960px){
    body{
        background: #000;
    }
}

這應(yīng)該算是media的一個(gè)標(biāo)準(zhǔn)寫法,上面這段CSS代碼的意思是:當(dāng)頁(yè)面小于960px的時(shí)候執(zhí)行它下面的CSS。

有人會(huì)發(fā)現(xiàn)上面這段代碼里面有個(gè)screen,它的意思是告知設(shè)備在打印頁(yè)面時(shí)使用襯線字體,在屏幕上顯示時(shí)用無(wú)襯線字體。但目前很多網(wǎng)站都會(huì)直接省略screen,因?yàn)榫W(wǎng)站如果不需要考慮用戶打印時(shí),可以直接這樣寫:

@media (max-width: 960px){
    body{
        background: #000;
    }
}

如果是瀏覽器尺寸大于960px的話:

@media screen and (min-width:960px){
    body{
        background:orange;
    }
}

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

@media screen and (min-width:960px) and (max-width:1200px){
    body{
        background:yellow;
    }
}

上面這段代碼的意思是當(dāng)頁(yè)面寬度大于960px且小于1200px的時(shí)候執(zhí)行下面的CSS。

Media所有參數(shù)匯總

以上是最常用到的媒體查詢器的三個(gè)特性,大于,等于,小于的寫法。媒體查詢器的全部功能肯定不止這三個(gè)功能,下面總結(jié)它的一些參數(shù)用法:

width:瀏覽器可視寬度。
height:瀏覽器可視高度。
device-width:設(shè)備屏幕的寬度。
device-height:設(shè)備屏幕的高度。
orientation:檢測(cè)設(shè)備目前處于橫向還是縱向狀態(tài)。
aspect-ratio:檢測(cè)瀏覽器可視寬度和高度的比例。(例如:aspect-ratio:16/9)
device-aspect-ratio:檢測(cè)設(shè)備的寬度和高度的比例。
color:檢測(cè)顏色的位數(shù)。(例如:min-color:32就會(huì)檢測(cè)設(shè)備是否擁有32位顏色)
color-index:檢查設(shè)備顏色索引表中的顏色,他的值不能是負(fù)數(shù)。
monochrome:檢測(cè)單色楨緩沖區(qū)域中的每個(gè)像素的位數(shù)。(這個(gè)太高級(jí),估計(jì)咱很少會(huì)用的到)
resolution:檢測(cè)屏幕或打印機(jī)的分辨率。(例如:min-resolution:300dpi或min-resolution:118dpcm)。
grid:檢測(cè)輸出的設(shè)備是網(wǎng)格的還是位圖設(shè)備。

注意以下順序,如果把@media (min-width: 768px)寫在了最下方,那么很悲劇:

@media (min-width: 1200){ //>=1200的設(shè)備 }
@media (min-width: 992px){ //>=992的設(shè)備 }
@media (min-width: 768px){ //>=768的設(shè)備 }

這是因?yàn)槿绻聊粚挾仁?440,由于1440>768那么1200就會(huì)失效。

所以在使用min-width時(shí),小的在前面,大的在后面;同理,如果使用max-width時(shí),就是大的在前面,小的在后面。
@media (min-width: 768px){ //>=768的設(shè)備 }
@media (min-width: 992px){ //>=992的設(shè)備 }
@media (min-width: 1200){ //>=1200的設(shè)備 }

@media (max-width: 1199){ //<=1199的設(shè)備 }
@media (max-width: 991px){ //<=991的設(shè)備 }
@media (max-width: 767px){ //<=768的設(shè)備 }

橫屏與豎屏

/* 豎屏 */  
@media screen and (orientation: portrait) and (max-width: 720px) { 對(duì)應(yīng)樣式 }  
  
/* 橫屏 */  
@media screen and (orientation: landscape) { 對(duì)應(yīng)樣式 } 

PC端按屏幕寬度大小排序

分辨率     比例 | 設(shè)備尺寸
1024*500    (8.9寸)
1024*768    (比例 4:3  | 10.4寸、12.1寸、14.1寸、15寸; )
1280*800    (比例 16:10  |15.4寸)
1280*1024   (比例 5:4  | 14.1寸、15.0寸)
1280*854    (比例 15:10 | 15.2)
1366*768    (比例 16:9 | 不常見)
1440*900    (比例 16:10  17寸 僅蘋果用)
1440*1050   (比例 5:4  | 14.1寸、15.0寸)
1600*1024   (比例 14:9  不常見)
1600*1200   (比例 4:3 | 15、16.1)
1680*1050   (比例 16:10 | 15.4寸、20.0寸)
1920*1200   (23寸)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容