日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

css3 media媒体查询器用法总结

發(fā)布時(shí)間:2025/3/15 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 css3 media媒体查询器用法总结 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

原文地址:http://www.cnblogs.com/zhaodifont/p/3858657.html

隨著響應(yīng)式設(shè)計(jì)模型的誕生,Web網(wǎng)站又要發(fā)生翻天腹地的改革浪潮,可能有些人會(huì)覺(jué)得在國(guó)內(nèi)IE6用戶居高不下的情況下,這些新的技術(shù)還不會(huì)廣泛的蔓延下去,那你就錯(cuò)了,如今淘寶,凡客,攜程等等公司都已經(jīng)在大膽的嘗試了這項(xiàng)技術(shù),并完美的應(yīng)用在了自己的網(wǎng)站上了。再不更新知識(shí)你就老了。我今天就總結(jié)一下響應(yīng)式設(shè)計(jì)的核心CSS技術(shù)Media(媒體查詢器)的用法。

?

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

首先我們?cè)谑褂肕edia的時(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è)備的寬度

    • 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以上了,所以這個(gè)時(shí)候就有又很多詭異的事情發(fā)生了,例如現(xiàn)在是IE9的瀏覽器,但是瀏覽器的文檔模式卻是IE8:

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

  • <meta?http-equiv="X-UA-Compatible"?content="IE=edge">
  • 太給力了。

    ?

    不過(guò)我最近又發(fā)現(xiàn)了一個(gè)更給力的寫法:

  • <meta?http-equiv="X-UA-Compatible"?content="IE=Edge,chrome=1">
  • 怎么這段代碼后面加了一個(gè)chrome=1,這個(gè)Google Chrome Frame(谷歌內(nèi)嵌瀏覽器框架GCF),如果有的用戶電腦里面裝了這個(gè)chrome的插件,就可以讓電腦里面的IE不管是哪個(gè)版本的都可以使用Webkit引擎及V8引擎進(jìn)行排版及運(yùn)算,無(wú)比給力,不過(guò)如果用戶沒(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;
  • ????}
  • }
  • 這個(gè)應(yīng)該算是一個(gè)media的一個(gè)標(biāo)準(zhǔn)寫法,上面這段CSS代碼意思是:當(dāng)頁(yè)面小于960px的時(shí)候執(zhí)行它下面的CSS.這個(gè)應(yīng)該沒(méi)有太大疑問(wèn)。

    ?

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

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

    CSS2 Media用法

    其實(shí)并不是只有CSS3才支持Media的用法,早在CSS2開(kāi)始就已經(jīng)支持Media,具體用法,就是在HTML頁(yè)面的head標(biāo)簽中插入如下的一段代碼:

  • <link?rel="stylesheet"?type="text/css"?media="screen"?href="style.css">
  • ?

    上面其實(shí)是CSS2實(shí)現(xiàn)的襯線用法,那CSS3的media難道就只能支持上面這一個(gè)功能嗎?答案當(dāng)然不是,他還有很多用法。

    ?

    例如我們想知道現(xiàn)在的移動(dòng)設(shè)備是不是縱向放置的顯示屏,可以這樣寫:

  • <link?rel="stylesheet"?type="text/css"?media="screen?and?(orientation:portrait)"?href="style.css">
  • ?

    我們把第一段的代碼也用CSS2來(lái)實(shí)現(xiàn),讓它一樣可以讓頁(yè)面寬度小于960的執(zhí)行指定的樣式文件:

  • <link?rel="stylesheet"?type="text/css"?media="screen?and?(max-width:960px)"?href="style.css">
  • ?

    既然CSS2可以實(shí)現(xiàn)CSS的這個(gè)效果為什么不用這個(gè)方法呢,很多人應(yīng)該會(huì)問(wèn),但是上面這個(gè)方法,最大的弊端是他會(huì)增加頁(yè)面http的請(qǐng)求次數(shù),增加了頁(yè)面負(fù)擔(dān),我們用CSS3把樣式都寫在一個(gè)文件里面才是最佳的方法。

    ?

    回歸CSS3 Media

    上面我們大概講了下CSS2的媒體查詢用法,現(xiàn)在我們重新回到CSS3的媒體查詢,在第一段代碼上面我用的是小于960px的尺寸的寫法,那現(xiàn)在我們來(lái)實(shí)現(xiàn)等于960px尺寸的代碼:

  • @media?screen?and?(max-device-width:960px){
  • ????body{
  • ????????background:red;
  • ????}
  • }
  • ?

    然后就是當(dāng)瀏覽器尺寸大于960px時(shí)候的代碼了:

  • @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è)備。

    轉(zhuǎn)載于:https://www.cnblogs.com/zjneter/p/5266108.html

    新人創(chuàng)作打卡挑戰(zhàn)賽發(fā)博客就能抽獎(jiǎng)!定制產(chǎn)品紅包拿不停!

    總結(jié)

    以上是生活随笔為你收集整理的css3 media媒体查询器用法总结的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。