隨著響應式設計模型的誕生河哑,Web網(wǎng)站又要發(fā)生翻天腹地的改革浪潮斑匪,可能有些人會覺得在國內(nèi)IE6用戶居高不下的情況下,這些新的技術還不會廣泛的蔓延下去盏浇,那你就錯了变丧,如今淘寶,凡客绢掰,攜程等等公司都已經(jīng)在大膽的嘗試了這項技術痒蓬,并完美的應用在了自己的網(wǎng)站上了。再不更新知識你就老了滴劲。我今天就總結一下響應式設計的核心CSS技術Media(媒體查詢器)的用法攻晒。
準備工作1:設置Meta標簽
首先我們在使用Media的時候需要先設置下面這段代碼,來兼容移動設備的展示效果:
這段代碼的幾個參數(shù)解釋:
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文件,來保證我們的代碼實現(xiàn)兼容效果:
準備工作3:設置IE渲染方式默認為最高(這部分可以選擇添加也可以不添加)
現(xiàn)在有很多人的IE瀏覽器都升級到IE9以上了聪姿,所以這個時候就有又很多詭異的事情發(fā)生了碴萧,例如現(xiàn)在是IE9的瀏覽器乙嘀,但是瀏覽器的文檔模式卻是IE8:
為了防止這種情況,我們需要下面這段代碼來讓IE的文檔模式永遠都是最新的:
太給力了破喻。
不過我最近又發(fā)現(xiàn)了一個更給力的寫法:
怎么這段代碼后面加了一個chrome=1虎谢,這個Google Chrome Frame(谷歌內(nèi)嵌瀏覽器框架GCF),如果有的用戶電腦里面裝了這個chrome的插件曹质,就可以讓電腦里面的IE不管是哪個版本的都可以使用Webkit引擎及V8引擎進行排版及運算婴噩,無比給力,不過如果用戶沒裝這個插件羽德,那這段代碼就會讓IE以最高的文檔模式展現(xiàn)效果几莽。這段代碼我還是建議你們用上,不過不用也是可以的宅静。
進入CSS3 Media寫法
我們先來看下下面這段代碼章蚣,估計很多人在響應式的網(wǎng)站CSS很經(jīng)常看到類似下面的這段代碼:
@media?screen?and?(max-width:?960px){
body{
background:?#000;
}
}
這個應該算是一個media的一個標準寫法姨夹,上面這段CSS代碼意思是:當頁面小于960px的時候執(zhí)行它下面的CSS.這個應該沒有太大疑問纤垂。
應該有人會發(fā)現(xiàn)上面這段代碼里面有個screen,他的意思是在告知設備在打印頁面時使用襯線字體磷账,在屏幕上顯示時用無襯線字體峭沦。但是目前我發(fā)現(xiàn)很多網(wǎng)站都會直接省略screen,因為你的網(wǎng)站可能不需要考慮用戶去打印時,你可以直接這樣寫:
@media?(max-width:?960px){
body{
background:?#000;
}
}
CSS2 Media用法
其實并不是只有CSS3才支持Media的用法逃糟,早在CSS2開始就已經(jīng)支持Media吼鱼,具體用法,就是在HTML頁面的head標簽中插入如下的一段代碼:
上面其實是CSS2實現(xiàn)的襯線用法履磨,那CSS3的media難道就只能支持上面這一個功能嗎蛉抓?答案當然不是,他還有很多用法剃诅。
例如我們想知道現(xiàn)在的移動設備是不是縱向放置的顯示屏巷送,可以這樣寫:
我們把第一段的代碼也用CSS2來實現(xiàn),讓它一樣可以讓頁面寬度小于960的執(zhí)行指定的樣式文件:
既然CSS2可以實現(xiàn)CSS的這個效果為什么不用這個方法呢矛辕,很多人應該會問笑跛,但是上面這個方法,最大的弊端是他會增加頁面http的請求次數(shù)聊品,增加了頁面負擔飞蹂,我們用CSS3把樣式都寫在一個文件里面才是最佳的方法。
回歸CSS3 Media
上面我們大概講了下CSS2的媒體查詢用法翻屈,現(xiàn)在我們重新回到CSS3的媒體查詢陈哑,在第一段代碼上面我用的是小于960px的尺寸的寫法,那現(xiàn)在我們來實現(xiàn)等于960px尺寸的代碼:
@media?screen?and?(max-device-width:960px){
body{
background:red;
}
}
然后就是當瀏覽器尺寸大于960px時候的代碼了:
@media?screen?and?(min-width:960px){
body{
background:orange;
}
}
我們還可以混合使用上面的用法:
@media?screen?and?(min-width:960px)?and?(max-width:1200px){
body{
background:yellow;
}
}
上面的這段代碼的意思是當頁面寬度大于960px小于1200px的時候執(zhí)行下面的CSS。
Media所有參數(shù)匯總
以上就是我們最常需要用到的媒體查詢器的三個特性惊窖,大于刽宪,等于,小于的寫法界酒。媒體查詢器的全部功能肯定不止這三個功能圣拄,下面是我總結的它的一些參數(shù)用法解釋:
width:瀏覽器可視寬度。
height:瀏覽器可視高度毁欣。
device-width:設備屏幕的寬度庇谆。
device-height:設備屏幕的高度。
orientation:檢測設備目前處于橫向還是縱向狀態(tài)凭疮。
aspect-ratio:檢測瀏覽器可視寬度和高度的比例饭耳。(例如:aspect-ratio:16/9)
device-aspect-ratio:檢測設備的寬度和高度的比例。
color:檢測顏色的位數(shù)执解。(例如:min-color:32就會檢測設備是否擁有32位顏色)
color-index:檢查設備顏色索引表中的顏色哥攘,他的值不能是負數(shù)。
monochrome:檢測單色楨緩沖區(qū)域中的每個像素的位數(shù)材鹦。(這個太高級,估計咱很少會用的到)
resolution:檢測屏幕或打印機的分辨率耕姊。(例如:min-resolution:300dpi或min-resolution:118dpcm)桶唐。
grid:檢測輸出的設備是網(wǎng)格的還是位圖設備。
轉(zhuǎn)載請注明來自520UEDhttp://www.520ued.com