這次帶給大家css3的新單位vw、vh、vmin、vmax應該如何使用,css3的新單位vw、vh、vmin、vmax使用的注意事項有哪些,下面就是實戰案例,一起來看一下。
本文介紹了css3新單位vw、vh、vmin、vmax的使用詳解,分享給大家,具體如下:
1,vw、vh、vmin、vmax 的含義
(1)vw、vh、vmin、vmax 是一種視窗單位,也是相對單位。它相對的不是父節點或頁面的根節點。而是由視窗(Viewport)大小來決定的,單位 1,代表類似 1%。
視窗(Viewport)是你的瀏覽器實際顯示內容的區域—,換句話說是你的不包含工具列和按鈕的網頁瀏覽器。
(2)具體描述如下:
vw:視窗寬度的百分比(1vw 代表視窗的寬度為1%)
vh:視窗高度的百分比
vmin:當前vw 和vh 中較小的一個值
vmax:當前vw 和vh 中較大的一個值
2,vw、vh 與% 百分比的差異
(1)%是相對於父元素的大小設定的比率,vw、vh 是視窗大小決定的。
(2)vw、vh 優點在於能夠直接取得高度,而用% 在沒有設定body 高度的情況下,是無法正確獲得可視區域的高度的,所以這是挺不錯的優勢。
3,vmin、vmax 用處
做移動頁面開發時,如果使用vw、wh 設定字體大小(例如5vw),在垂直螢幕和橫向螢幕狀態下顯示的字體大小是不一樣的。
由於 vmin 和 vmax 是目前較小的 vw 和 vh 和目前較大的 vw 和 vh。這裡就可以用到 vmin 和 vmax。使得文字大小在橫向螢幕下保持一致。
4,瀏覽器相容性
(1)桌面PC
Chrome:自26 版起就完美支援(2013年2月)
Firefox:自19 版起就完美支持(2013年1月)
Safari:自6.1 版起就完美支持(2013年10月)
Opera:自15 版起就完美支持(2013年7月)
IE:自IE10 起(包括Edge)到現在還只是部分支援(不支援vmax,同時vm 代替vmin)
(2)行動裝置
Android:自4.4 版起就完美支援(2013年12月)
iOS:自iOS8 版起就完美支援(2014年9月)
二、一個簡單的範例
1,頁碼
視窗(Viewport)單位除了可以用來設定元素的寬高尺寸,也可以在文字中使用。下面使用 vw 設定字體大小來實現響應式文字。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>hangge.com</title> <style> html, body, div, span, h1, h2, h3 { margin: 0; padding: 0; border: 0; } .demo { width: 100vw; font-size: 5vw; margin: 0 auto; background-color: #50688B; color: #FFF; } .demo2 { width: 80vw; font-size: 5vw; margin: 0 auto; background-color: #ff6a00; } .demo3 { width: 50vw; height: 50vh; font-size: 1vw; margin: 0 auto; background-color: #ff006e; color: #FFF; } </style> </head> <body> <div class="demo"> <h1 id="宽度-nbsp-字体">宽度100%, 字体5%</h1> </div> <div class="demo2"> <h2 id="宽度-nbsp-字体">宽度80%, 字体5%</h2> </div> <div class="demo3"> <h3 id="宽度-nbsp-高度-nbsp-字体">宽度50%, 高度50%, 字体1%</h3> </div> </body> </html>
三、實現完整覆蓋的遮罩層
#有時為了突出彈出框,或避免頁面元素被點擊。我們需要一個覆蓋整個視覺區域的半透明遮罩,這個使用 vw、vh 就可以很輕易地實現。
1,範例程式碼
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>hangge.com</title> <style> html, body, div, span, button { margin: 0; padding: 0; border: 0; } button { width: 120px; height: 30px; color: #FFFFFF; font-family: "微软雅黑"; font-size: 14px; background: #28B995; } #mask { width: 100vw; height: 100vh; position: fixed; top: 0; left: 0; background: #000000; opacity: 0.5; display: none; } </style> </head> <body> <button onclick="document.getElementById('mask').style.display='inline'">点击显示遮罩</button> <div id="mask" onclick="document.getElementById('mask').style.display='none'"/></div> </body> </html>
四、實作居中顯示的彈出框
1,彈出框大小隨內容自適應
(1)範例效果圖
點選彈出按鈕後,會顯示一個在整個螢幕上居中顯示的彈出框。
彈出框的大小會根據內容的大小自適應(logo 圖片),同時彈出框後面還有一個覆蓋整個螢幕的半透明遮罩層。
點選關閉按鈕後,則隱藏彈出框。
(2)範例程式碼
遮罩層使用 vw、vh 實作全螢幕覆蓋。彈出框新增至遮罩層並居中。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>hangge.com</title> <script type="text/javascript" src="js/jquery.js"></script> <style> html, body, div, span, button { margin: 0; padding: 0; border: 0; } button { width: 120px; height: 30px; color: #FFFFFF; font-family: "微软雅黑"; font-size: 14px; background: #28B995; } .dialog-container { display: none; width: 100vw; height: 100vh; background-color: rgba(0,0,0,.35); text-align: center; position: fixed; top: 0; left: 0; z-index: 10; } .dialog-container:after { display: inline-block; content: ''; width: 0; height: 100%; vertical-align: middle; } .dialog-box { display: inline-block; border: 1px solid #ccc; text-align: left; vertical-align: middle; position: relative; } .dialog-title { line-height: 28px; padding-left: 5px; padding-right: 5px; border-bottom: 1px solid #ccc; background-color: #eee; font-size: 12px; text-align: left; } .dialog-close { position: absolute; top: 5px; right: 5px; font-size: 12px; } .dialog-body { background-color: #fff; } </style> </head> <body> <button onclick="$('#dialogContainer').show();">点击显示弹出框</button> <div id="dialogContainer" class="dialog-container"> <div class="dialog-box"> <div class="dialog-title">居中弹出框</div> <a onclick="$('#dialogContainer').hide();" class="dialog-close">关闭</a> <div class="dialog-body"> <img class="demo-image lazy" src="/static/imghwm/default1.png" data-src="logo.png" / alt="css3的新單位vw、vh、vmin、vmax應該如何使用" > </div> </div> </div> </body> </html>
2,彈出框大小隨視窗大小改變
(1)範例效果圖
點擊彈出按鈕後,會顯示一個在整個螢幕上居中顯示的彈出框。
彈出框的大小不再由內容的大小決定,而是隨視窗大小改變(寬高皆為螢幕視覺區域的 80%)。
點選關閉按鈕後,則隱藏彈出框。
(2)範例程式碼
遮罩層使用 vw、vh 實作全螢幕覆蓋。而彈出框的尺寸位置同樣使用 vw、vh 設定。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>hangge.com</title> <script type="text/javascript" src="js/jquery.js"></script> <style> html, body, div, span, button { margin: 0; padding: 0; border: 0; } button { width: 120px; height: 30px; color: #FFFFFF; font-family: "微软雅黑"; font-size: 14px; background: #28B995; } .dialog-container { display: none; width: 100vw; height: 100vh; background-color: rgba(0,0,0,.35); text-align: center; position: fixed; top: 0; left: 0; z-index: 10; } .dialog-box { top:10vh; left:10vw; width: 80vw; height: 80vh; text-align: left; position: absolute; border: 1px solid #ccc; display: flex; flex-direction: column; } .dialog-title { line-height: 28px; padding-left: 5px; padding-right: 5px; border-bottom: 1px solid #ccc; background-color: #eee; font-size: 12px; text-align: left; } .dialog-close { position: absolute; top: 5px; right: 5px; font-size: 12px; } .dialog-body { background-color: #fff; flex:1; overflow: auto; } </style> </head> <body> <button onclick="$('#dialogContainer').show();">点击显示弹出框</button> <div id="dialogContainer" class="dialog-container"> <div class="dialog-box"> <div class="dialog-title">居中弹出框</div> <a onclick="$('#dialogContainer').hide();" class="dialog-close">关闭</a> <div class="dialog-body"> <img class="demo-image lazy" src="/static/imghwm/default1.png" data-src="logo.png" / alt="css3的新單位vw、vh、vmin、vmax應該如何使用" > </div> </div> </div> </body> </html>
五、顯示大圖時限制其最大尺寸
我們也可以透過視圖單位來限制一些元素的最大寬度或高度,避尺寸過大而超出螢幕。
(1)點選按鈕,在螢幕中央顯示原始圖片的大圖。
(2) 若圖片原始寬高皆不超過螢幕寬高的 90%,則顯示圖片的預設大小。
(3)如果圖片原始寬高均超過螢幕寬高的 90%,則限制為螢幕的 90%,使其能夠完全顯示。
相信看了這些案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
相關閱讀:
用H5的WebGL如何在同一個介面做出json和echarts圖表
以上是css3的新單位vw、vh、vmin、vmax應該如何使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

具有CSS的自定義光標很棒,但是我們可以將JavaScript提升到一個新的水平。使用JavaScript,我們可以在光標狀態之間過渡,將動態文本放置在光標中,應用複雜的動畫並應用過濾器。

互動CSS動畫和元素相互啟動的元素在2025年似乎更合理。雖然不需要在CSS中實施乒乓球,但CSS的靈活性和力量的增加,可以懷疑Lee&Aver Lee有一天會成為一種

有關利用CSS背景濾波器屬性來樣式用戶界面的提示和技巧。您將學習如何在多個元素之間進行背景過濾器,並將它們與其他CSS圖形效果集成在一起以創建精心設計的設計。

好吧,事實證明,SVG的內置動畫功能從未按計劃進行棄用。當然,CSS和JavaScript具有承載負載的能力,但是很高興知道Smil並沒有像以前那樣死在水中

是的,讓#039;跳上文字包裝:Safari Technology Preview In Pretty Landing!但是請注意,它與在鉻瀏覽器中的工作方式不同。

此CSS-tricks更新了,重點介紹了年鑑,最近的播客出現,新的CSS計數器指南以及增加了幾位新作者,這些新作者貢獻了有價值的內容。

在大多數情況下,人們展示了@Apply的@Apply功能,其中包括Tailwind的單個property實用程序之一(會改變單個CSS聲明)。當以這種方式展示時,@Apply聽起來似乎很有希望。如此明顯


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

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