淺談css3 device-width和width之間的差異
這篇文章和大家談談css媒體查詢中device-width與width的差別。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。
【推薦教學:CSS影片教學 】
1.device-width
定義:定義輸出裝置的螢幕可見寬度。
不管你的網頁是在safari打開還是嵌在某個webview中,device-width都只跟你的設備有關,如果是同一個設備,那麼他的值就不會變。
例如iphone6的device-width*device-height為375*667,而跟他的dpr等無關。
2.width
定義:定義輸出裝置中的頁面可見區域寬度。
輸出的是你的網頁可見區域的寬高,假設你的網頁是行動裝置網頁嵌套在某個webview中,width其實就是webview的寬高,如果在不同的瀏覽器中,width和height也有可能不一樣,又假如,你的頁面用的rem佈局,並且對於retina屏來說dpr>1,meta標籤中設置了content="width=device-width, initial-scale=0.5, minimum-scale=0.5, maximum-scale=0.5, user-scalable=no,viewport-fit=cover",你的iphone6上的width大小就為750px了。
我這裡用得比較用得多的是device-width和device-height,因為不用考慮橫屏的情況
比如說適配iphoneX,你已經明確知道了iphoneX( 375*812)的尺寸就可以用下面語句:
/*iphone x*/ @media only screen and (device-width:375px) and (device-height:812px) and (-webkit-device-pixel-ratio:3) { .foriphoneX() }
又例如最新的三星折疊螢幕
@media screen and (device-width: 586px) and (device-height: 820px){ html{ font-size: 110px !important; } }
總之,device-width在一個裝置中是不會變的,他的值跟裝置寬度有關,width在不同的佈局方案或不同的容器中展示都有可能不一樣,這裡我覺得device-width就相當於js的window.screen.width,width相當於js的document .body.clientWidth了。
另外錄下我這裡適配華為折疊螢幕的情況,由於此時還沒真機,我只知道華為展開情況下的解析度為2200*2480,dpr什麼的還不清楚,因此不知道device-width和device-height(我這邊不能用width來做查詢,原因關係到業務邏輯),因此選了device-aspect-ratio,
最開始我在我的less中是這樣寫的
@media (device-aspect-ratio: 55/62) { /*适配*/ }
然後css中device-aspect-ratio被計算成小數了
@media (device-aspect-ratio: 0.887097) { /*适配*/ }
device-aspect-ratio是不支援小數的,因此匹配不上
所以查了一下怎麼讓less不執行55/62的結果,發現將屬性用引號包起來,並且前面加上波浪號就可以了,像這樣:
@media (device-aspect-ratio: ~"55/62") { /*适配部分*/ }
問題解決!
不過MDN上已經不推薦使用device-aspect-ratio了,這個屬性將會被逐廢棄,如果找到了更好的解決方案我也會用替代方案。
更多程式相關知識,請造訪:程式設計入門! !
以上是淺談css3 device-width和width之間的差異的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

純CSS3怎麼實現波浪效果?這篇文章就來跟大家介紹一下使用 SVG 和 CSS 動畫來製作波浪效果的方法,希望對大家有幫助!

兩種方法:1、利用display屬性,只要為元素加上「display:none;」樣式即可。 2.利用position和top屬性設定元素絕對定位來隱藏元素,只需為元素加上「position:absolute;top:-9999px;」樣式。

在css中,可以利用border-image屬性來實作花邊邊框。 border-image屬性可以使用圖片來建立邊框,即給邊框加上背景圖片,只需要將背景圖片指定為花邊樣式即可;語法「border-image: url(圖片路徑) 向內偏移值圖像邊界寬度outset 是否重複;」。

實作方法:1、使用「:active」選擇器選取滑鼠點擊圖片的狀態;2、使用transform屬性和scale()函數實現圖片放大效果,語法「img:active {transform: scale(x軸放大倍率,y軸放大倍率);}」。

怎麼製作文字輪播與圖片輪播?大家第一想到的是利用js,其實利用純CSS也能實現文字輪播與圖片輪播,下面來看看實作方法,希望對大家有幫助!

在css3中,可以利用「animation-timing-function」屬性來設定動畫旋轉速度,該屬性用於指定動畫將如何完成一個週期,設定動畫的速度曲線,語法為「元素{animation-timing-function:速度屬性值;}」。

在html5中,width的意思是寬度,width屬性定義元素內容區的寬度,在內容區外面可以增加內邊距、邊框和外邊距,只需要給元素設定「元素{width:數值}」即可。
