久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

聊聊為什么不應該依賴CSS 100vh?

為什么不應該依賴CSS 100vh?下面本篇文章就來帶大家聊聊原因,希望對大家有所幫助!

聊聊為什么不應該依賴CSS 100vh?

前端(vue)入門到精通課程:進入學習
API 文檔、設計、調試、自動化測試一體化協作工具:點擊使用

如果有一個文本和一個按鈕,我們想讓文本粘在上面,而按鈕粘在下面!使用CSS Flex 似乎很容易做到。【推薦學習:css視頻教程】

// HTML <div className="layout">   <p>Lorem ipsum dolor sit amet...</p>   <button>Sign Up</button> </div>  // CSS .layout {   display: flex;   flex-direction: column;   justify-content: space-between;   min-height: 100vh; }

在真機檢查一下效果:

聊聊為什么不應該依賴CSS 100vh?

酷! Git add, git commit, git push, oh yeah!

這有什么問題嗎?

當然,是有的! 要看到這個問題,你需要在真實的手機或模擬器上查看你的應用程序。在本文中使用的 iPhone 13(iOS 15.2)進行測試,下面是結果:

聊聊為什么不應該依賴CSS 100vh?

啥,底部按鈕跑哪里去了?

順便說一下,它在安卓手機上甚至不能按預期工作。

聊聊為什么不應該依賴CSS 100vh?

為什么100vh問題會發生在移動設備上?

我對這個問題進行了一番調查,發現了其中的原因。簡短的答案是,瀏覽器的工具欄高度沒有被考慮在內。如果你想深入了解為什么會發生這種情況,Stack Overflow的這個帖子很有幫助。

如何修復移動設備上的100vh問題?

第一個建議是盡量少用 vh。例如,在上面的代碼中,你可以使用一個 sticky 按鈕,避免使用vh單位。

// HTML <div className="layout">   <p>Lorem ipsum dolor sit amet...</p>   <button>Sign Up</button> </div>  // CSS .layout {   display: flex;   flex-direction: column;   justify-content: space-between;   min-height: 100vh; } .layout button {   position: sticky;   bottom: 0; }

效果:

聊聊為什么不應該依賴CSS 100vh?

它在橫向模式下也很好:

聊聊為什么不應該依賴CSS 100vh?

說實話,結果是好的,但你不能總是用 sticky 元素來解決 100vh 的問題。

僅使用 CSS 在移動設備上修復 100VH 問題

時,使用 vh 的目的是為了簡單地創建與視口高度相等的部分。例如,當你在建立登陸頁面時,這很常見。在這些情況下,position sticky不會有幫助,這里介紹一下 fill-available屬性。它用起來很簡單,只要記住使用前綴和回退值就可以了。

.layout {   min-height: 100vh;            /* fall-back */   min-height: -moz-available;   min-height: -webkit-fill-available;   min-height: fill-available; }

效果:
聊聊為什么不應該依賴CSS 100vh?

而且,當你旋轉設備時,它還會更新高度,太棒了!

聊聊為什么不應該依賴CSS 100vh?

fill-available 修復 100vh 的問題確實很直接,但在調查這個解決方案時,也遇到過一些問題。

1. HTML類型聲明問題

頁面上有 <!DOCTYPE html> 聲明,會使 fill-available 在 Chrome 瀏覽器上無法正常工作。

聊聊為什么不應該依賴CSS 100vh?

甚至不能在安卓瀏覽器上工作:

聊聊為什么不應該依賴CSS 100vh?

因此,為了解決這個問題,必須從頁面中刪除 doctype 聲明。

2. Safari上的垂直 padding 問題

min-height(或 height)為 fill-available的元素上添加垂直 padding (bottom 和 top),Safari瀏覽器上會導致問題,高度不會正確。

聊聊為什么不應該依賴CSS 100vh?

要解決這個問題,只需將你的內容包在另一個 div 元素內,就可以了:

// HTML <div class="screen">   <div class="content">     ...   </div> </div>  // CSS .screen {   background-color: mediumpurple;   min-height: 100vh;   min-height: -moz-available;   min-height: -webkit-fill-available;   min-height: fill-available; } .content {   color: #fff;   display: flex;   flex-direction: column;   justify-content: center;   height: 100%;   padding: 30px; }

3. fill-available 不能與 calc() 一起使用

需要注意的一件事是,不能在 fill-available 屬性下使用 calc()。所以,下面的CSS規則就不會生效:

min-height: calc(-webkit-fill-available / 2);

例如,如果需要在元素上有一半的可用高度,必須使用JavaScript。

使用JavaScript修復移動設備上的100vh問題

可以使用 window 的 innerHeight 屬性,將元素 height (或minHeight)設置為window.innerHeight,如下所示:

<!DOCTYPE html> <html> <head>   <style>     ...   </style> </head> <body> <div id="intro">   <h1>Hello World!</h1>   <h2>The height of this area is equal to...</h2> </div> ... <script>   (function () {     const el = document.getElementById('intro');     el.style.minHeight = window.innerHeight + 'px';   })(); </script> </body> </html>

效果:

聊聊為什么不應該依賴CSS 100vh?

接著,再介紹一種花銷的方式。 一些開發者喜歡根據窗口的內部高度定義一個CSS變量,并使用該變量來設計他們所需的元素。代碼如下:

// 以像素為單位計算1vh值 // 基于窗口的內部高度 var vh = window.innerHeight * 0.01;  //  將CSS變量設置為根元素 // 相當于1vh document.documentElement.style.setProperty('--vh', vh + 'px');

在 CSS 中:

min-height: calc(var(--vh) * 100);

最后一件事是當窗口被調整大小或設備方向改變時,重新計算這個值:

function calculateVh() {   var vh = window.innerHeight * 0.01;   document.documentElement.style.setProperty('--vh', vh + 'px'); }  // 初始計算 calculateVh();  // 調整大小時重新計算 window.addEventListener('resize', calculateVh);  // 在設備方向改變時重新計算 window.addEventListener('orientationchange', calculateVh);

在我看來,你應該先用CSS的解決方案。

(學習視頻分享:css視頻教程、web前端)

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
国产精品免费看| 日本麻豆一区二区三区视频| 美腿丝袜在线亚洲一区| 国产激情一区| 成人久久久久| 蜜桃久久精品一区二区| 在线一区二区三区视频| 日本国产亚洲| 国产精品亚洲综合在线观看| 久久av影视| 欧美日韩中文字幕一区二区三区| 免费久久精品| 国产欧美另类| 久久九九国产| 91精品国产自产观看在线| 精品久久久网| 爽爽淫人综合网网站| 久久gogo国模啪啪裸体| 国产二区精品| 国产精品亚洲欧美日韩一区在线 | 欧美日韩在线观看首页| 成人日韩av| 99香蕉国产精品偷在线观看| 国产一级成人av| 亚洲调教视频在线观看| 日本国产亚洲| 日韩影院在线观看| 精品99在线| 日韩免费精品| 中文一区二区| 正在播放日韩精品| 国产探花一区| 久久高清一区| 午夜国产一区二区| 91看片一区| 精品视频在线你懂得| 99综合视频| 久久精品导航| 久久亚洲人体| 久久尤物视频| 国产精品xxx在线观看| 国产视频亚洲| 日韩av中文字幕一区二区| 国产精品一级| 日韩精品a在线观看91| 美女久久久久| 999精品一区| 国产精品99一区二区三| 国产精品1luya在线播放| 中文字幕乱码亚洲无线精品一区| 精品国模一区二区三区| 国产日韩欧美一区二区三区| 美女毛片一区二区三区四区| 亚洲天堂av影院| 伊人网在线播放| 日韩av专区| 国产色播av在线| 高清日韩欧美| av综合电影网站| 久久亚洲成人| 日韩视频一区| 99国产精品| 在线综合亚洲| 免费欧美日韩| 亚洲精选91| 日韩av不卡一区二区| 综合亚洲色图| 日韩精品a在线观看91| 国产欧美另类| 激情国产在线| 91精品国产调教在线观看| 欧美日韩一二| 亚洲色图网站| 国产精品久久久久久久久久久久久久久| 国产精品香蕉| av日韩中文| 国产精品外国| 久久xxx视频| 激情欧美日韩一区| 蜜桃久久精品一区二区| 亚州精品视频| 欧美aa在线视频| 精品资源在线| 婷婷综合网站| 国产精品一线| 欧美日韩精品一本二本三本| 亚洲日本免费电影| 91日韩欧美| 天堂成人免费av电影一区| 欧美天堂在线| 日本а中文在线天堂| 99在线精品视频在线观看| 国产精品99精品一区二区三区∴ | 日本麻豆一区二区三区视频| 97人人精品| 日韩二区三区在线观看| 国产精品精品| 丝袜美腿成人在线| 精品国产亚洲一区二区三区大结局| 激情综合网站| 国产精品jk白丝蜜臀av小说| 夜久久久久久| 国产91欧美| 深夜福利一区| 激情综合自拍| 日本一二区不卡| 久久国产免费看| 在线免费观看亚洲| 国产成人精选| 国产精品美女在线观看直播| 免费在线看一区| 亚洲精品一区二区妖精| 美女福利一区二区三区| 欧美激情在线精品一区二区三区| 午夜电影亚洲| 私拍精品福利视频在线一区| 麻豆一区二区99久久久久| 欧美影院精品| 日韩不卡一区二区| 日韩精品一区第一页| 女主播福利一区| 黄色日韩精品| 蘑菇福利视频一区播放| 樱桃视频成人在线观看| www在线观看黄色| 国产成人精品一区二区三区免费| 国产精区一区二区| 国产精品密蕾丝视频下载| 国产日韩中文在线中文字幕| 日韩中文av| 日韩有吗在线观看| 日本久久二区| 日韩av资源网| 久久精品资源| 久久久蜜桃一区二区人| 久久久久久久久久久9不雅视频| 久久一区二区三区喷水| 在线综合亚洲| 亚洲狼人精品一区二区三区| 91午夜精品| 日本不良网站在线观看| 国产尤物精品| 在线视频亚洲欧美中文| 国产精品视频首页| 视频在线不卡免费观看| 米奇777超碰欧美日韩亚洲| 亚洲一区二区三区中文字幕在线观看| 最新亚洲国产| 老鸭窝一区二区久久精品| 久久久久国产精品一区三寸| 久久成人亚洲| 精品三级在线观看视频| 不卡在线一区| 日韩三级精品| 成人精品视频| 日韩综合小视频| 日韩和的一区二在线| 日本欧美久久久久免费播放网| 精品欧美一区二区三区在线观看| 国产毛片一区| 日本久久黄色| 日韩国产欧美视频| 欧美日韩国产综合网| 精品久久久网| 日本久久一区| 午夜国产欧美理论在线播放| 欧美交a欧美精品喷水| 亚洲精品极品| 日韩在线第七页| 日韩av午夜在线观看| 99视频精品| 韩国久久久久久| 欧美日韩亚洲三区| 国产精品婷婷| 日韩在线观看一区| 国产精品二区影院| 日韩高清一区二区| 亚洲一区导航| 噜噜噜躁狠狠躁狠狠精品视频 | 日韩国产欧美在线播放| 蜜桃国内精品久久久久软件9| 久久精品免费看| 欧美另类中文字幕| 四虎精品一区二区免费| 久久亚洲影院| 亚洲欧美高清| 免费观看久久av| 韩国三级一区| 免费看av不卡| 中文字幕系列一区| 国产精品精品国产一区二区| 麻豆中文一区二区| 欧美激情五月| 日本少妇一区二区| 日韩精品导航| 国产精品网在线观看| 国产精品流白浆在线观看| 国产精品一区二区三区四区在线观看| 日韩影片在线观看| 国产人成精品一区二区三|