<ins id="5f050"></ins>
                1. <menuitem id="5f050"></menuitem>
                  1. 西安力洋網站建設

                    西安力洋網絡
                  2. 利用@media screen實現自適應響應式網頁布局

                  3. 發布者:本站 發布時間:2020/12/24 9:41:57
                  4. 今天想了解下網站自適應是怎么實現的,看到這篇文章自己覺得特別好,就保存下來。也供更多的朋友了解學習下。

                    優點:無需插件和手機主題,對移動設備友好,能夠適應各種窗口大小。只需在CSS中添加@media screen屬性,根據瀏覽器寬度判斷并輸出不同的長寬值

                    準備工作1:設置Meta標簽
                    首先我們在使用Media的時候需要先設置下面這段代碼,來兼容移動設備的展示效果:

                    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
                    這段代碼的幾個參數解釋:

                    width = device-width:寬度等于當前設備的寬度

                    height = device-height:高度等于當前設備的高度

                    initial-scale:初始的縮放比例(默認設置為1.0)  

                    minimum-scale:允許用戶縮放到的最小比例(默認設置為1.0)    

                    maximum-scale:允許用戶縮放到的最大比例(默認設置為1.0)   

                    user-scalable:用戶是否可以手動縮放(默認設置為no,因為我們不希望用戶放大縮小頁面) 

                     

                    準備工作2:加載兼容文件JS
                    因為IE8既不支持HTML5也不支持CSS3 Media,所以我們需要加載兩個JS文件,來保證我們的代碼實現兼容效果:

                    <!--[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]-->
                     

                    準備工作3:設置IE渲染方式默認為最高(這部分可以選擇添加也可以不添加)
                    現在有很多人的IE瀏覽器都升級到IE9以上了,所以這個時候就有又很多詭異的事情發生了,例如現在是IE9的瀏覽器,但是瀏覽器的文檔模式卻是IE8:

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

                    <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">
                    怎么這段代碼后面加了一個chrome=1,這個Google Chrome Frame(谷歌內嵌瀏覽器框架GCF),如果有的用戶電腦里面裝了這個chrome的插件,就可以讓電腦里面的IE不管是哪個版本的都可以使用Webkit引擎及V8引擎進行排版及運算,無比給力,不過如果用戶沒裝這個插件,那這段代碼就會讓IE以最高的文檔模式展現效果。這段代碼我還是建議你們用上,不過不用也是可以的。

                    進入CSS3 Media寫法
                    我們先來看下下面這段代碼,估計很多人在響應式的網站CSS很經?吹筋愃葡旅娴倪@段代碼:

                    @media screen and (max-width: 960px){
                        body{
                            background: #000;
                        }
                    }
                    這個應該算是一個media的一個標準寫法,上面這段CSS代碼意思是:當頁面小于960px的時候執行它下面的CSS.這個應該沒有太大疑問。

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

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

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

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

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

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

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

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

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

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

                    回歸CSS3 Media
                    上面我們大概講了下CSS2的媒體查詢用法,現在我們重新回到CSS3的媒體查詢,在第一段代碼上面我用的是小于960px的尺寸的寫法,那現在我們來實現等于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的時候執行下面的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:檢測輸出的設備是網格的還是位圖設備。

                     

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

                    @media (min-width: 1200){ //>=1200的設備 }

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

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

                    因為如果是1440,由于1440>768那么你的1200就會失效。

                    所以我們用min-width時,小的放上面大的在下面,同理如果是用max-width那么就是大的在上面,小的在下面

                    @media (max-width: 1199){ //<=1199的設備 }

                    @media (max-width: 991px){ //<=991的設備 }

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


                    1280分辨率以上(大于1200px)

                    @media screen and (min-width:1200px){
                        #page{ width: 1100px; }#content,.div1{width: 730px;}#secondary{width:310px}
                    }

                    1100分辨率(大于960px,小于1199px)

                    @media screen and (min-width: 960px) and (max-width: 1199px) {
                        #page{ width: 960px; }#content,.div1{width: 650px;}#secondary{width:250px}select{max-width:200px}
                    }
                     

                    880分辨率(大于768px,小于959px)

                    @media screen and (min-width: 768px) and (max-width: 959px) {
                        #page{ width: 900px; }#content,.div1{width: 620px;}#secondary{width:220px}select{max-width:180px}
                    }
                     

                    720分辨率(大于480px,小于767px)

                    @media only screen and (min-width: 480px) and (max-width: 767px){
                        #page{ width: 450px; }#content,.div1{width: 420px;position: relative; }#secondary{display:none}#access{width: 450px; }#access a {padding-right:5px}#access a img{display:none}#rss{display:none}#branding #s{display:none}
                    }
                     

                    440分辨率以下(小于479px)

                    @media only screen and (max-width: 479px) {
                        #page{ width: 300px; }#content,.div1{width: 300px;}#secondary{display:none}#access{width: 330px;} #access a {padding-right:10px;padding-left:10px}#access a img{display:none}#rss{display:none}#branding #s{display:none}#access ul ul a{width:100px}
                    }
                     

                     
                    /* 豎屏 */

                    @media screen and (orientation: portrait) and (max-width: 720px) { 對應樣式 }

                     
                    /* 橫屏 */

                    @media screen and (orientation: landscape) { 對應樣式 }


                    上面的代碼中用到了screen ,他的意思是在告知設備在打印頁面時使用襯線字體,在屏幕上顯示時用無襯線字體。但是目前我發現很多網站都會直接省略screen,因為你的網站可能不需要考慮用戶去打印時。

                     
                    PC端按屏幕寬度大小排序(主流的用橙色標明)

                    分辨率   比例 | 設備尺寸

                    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寸)

                    通過上面的電腦屏蔽及尺寸的例表上我們得到了幾個寬度
                    1024  1280  1366  1440  1680  1920  

                    CSS代碼

                    @media (min-width: 1024px){
                      body{font-size: 18px}
                    } /*>=1024的設備*/
                    @media (min-width: 1100px) {
                      body{font-size: 20px}
                    } /*>=1024的設備*/
                    @media (min-width: 1280px) {
                      body{font-size: 22px;}

                    @media (min-width: 1366px) {
                      body{font-size: 24px;}
                    }  
                    @media (min-width: 1440px) {
                      body{font-size: 25px !important;}

                    @media (min-width: 1680px) {
                      body{font-size: 28px;}

                    @media (min-width: 1920px) {
                      body{font-size: 33px;}



                    轉載自:http://www.cnblogs.com/xcxc/p/4531846.html

                     http://www.cnblogs.com/zhaodifont/p/3858657.html

                     http://www.bubuko.com/infodetail-1045273.html


                  5. 返回列表
                    相關閱讀
                    更多
                    深度挖掘網站的商用價值,化繁為簡的設計,為企業找到直接有效的解決方案
                    +86 (029) 88765320
                    +86 15829904657
                    地址:西安市未央區文景路11號
                    星舍大廈5F P.C:7100001
                    boss@178365.net
                    在線咨詢: 985224206
                    中國互聯網協會成員單位
                    西安力洋之星網絡技術有限公司 | 版權所有
                    Copyright 2008-2020 Liyang.Inc All Rights Reserved.
                    Liyang.Inc
                    国产亚洲视品在线_暖暖在线看免费观看视频6_亚洲爱婷婷色婷婷五月_一品道一卡二卡三卡
                            <ins id="5f050"></ins>
                                1. <menuitem id="5f050"></menuitem>
                                  1. <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <文本链> <文本链> <文本链> <文本链> <文本链> <文本链>