欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長(zhǎng)資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          為什么不應(yīng)該依賴CSS 100vh?下面本篇文章就來(lái)帶大家聊聊原因,希望對(duì)大家有所幫助!

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          前端(vue)入門到精通課程:進(jìn)入學(xué)習(xí)
          API 文檔、設(shè)計(jì)、調(diào)試、自動(dòng)化測(cè)試一體化協(xié)作工具:點(diǎn)擊使用

          如果有一個(gè)文本和一個(gè)按鈕,我們想讓文本粘在上面,而按鈕粘在下面!使用CSS Flex 似乎很容易做到?!就扑]學(xué)習(xí):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; }

          在真機(jī)檢查一下效果:

          聊聊為什么不應(yīng)該依賴CSS 100vh?

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

          這有什么問(wèn)題嗎?

          當(dāng)然,是有的! 要看到這個(gè)問(wèn)題,你需要在真實(shí)的手機(jī)或模擬器上查看你的應(yīng)用程序。在本文中使用的 iPhone 13(iOS 15.2)進(jìn)行測(cè)試,下面是結(jié)果:

          聊聊為什么不應(yīng)該依賴CSS 100vh?

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

          順便說(shuō)一下,它在安卓手機(jī)上甚至不能按預(yù)期工作。

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          為什么100vh問(wèn)題會(huì)發(fā)生在移動(dòng)設(shè)備上?

          我對(duì)這個(gè)問(wèn)題進(jìn)行了一番調(diào)查,發(fā)現(xiàn)了其中的原因。簡(jiǎn)短的答案是,瀏覽器的工具欄高度沒(méi)有被考慮在內(nèi)。如果你想深入了解為什么會(huì)發(fā)生這種情況,Stack Overflow的這個(gè)帖子很有幫助。

          如何修復(fù)移動(dòng)設(shè)備上的100vh問(wèn)題?

          第一個(gè)建議是盡量少用 vh。例如,在上面的代碼中,你可以使用一個(gè) 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; }

          效果:

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          它在橫向模式下也很好:

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          說(shuō)實(shí)話,結(jié)果是好的,但你不能總是用 sticky 元素來(lái)解決 100vh 的問(wèn)題。

          僅使用 CSS 在移動(dòng)設(shè)備上修復(fù) 100VH 問(wèn)題

          時(shí),使用 vh 的目的是為了簡(jiǎn)單地創(chuàng)建與視口高度相等的部分。例如,當(dāng)你在建立登陸頁(yè)面時(shí),這很常見(jiàn)。在這些情況下,position sticky不會(huì)有幫助,這里介紹一下 fill-available屬性。它用起來(lái)很簡(jiǎn)單,只要記住使用前綴和回退值就可以了。

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

          效果:
          聊聊為什么不應(yīng)該依賴CSS 100vh?

          而且,當(dāng)你旋轉(zhuǎn)設(shè)備時(shí),它還會(huì)更新高度,太棒了!

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          fill-available 修復(fù) 100vh 的問(wèn)題確實(shí)很直接,但在調(diào)查這個(gè)解決方案時(shí),也遇到過(guò)一些問(wèn)題。

          1. HTML類型聲明問(wèn)題

          頁(yè)面上有 <!DOCTYPE html> 聲明,會(huì)使 fill-available 在 Chrome 瀏覽器上無(wú)法正常工作。

          聊聊為什么不應(yīng)該依賴CSS 100vh?

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

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          因此,為了解決這個(gè)問(wèn)題,必須從頁(yè)面中刪除 doctype 聲明。

          2. Safari上的垂直 padding 問(wèn)題

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

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          要解決這個(gè)問(wèn)題,只需將你的內(nèi)容包在另一個(gè) div 元素內(nèi),就可以了:

          // 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規(guī)則就不會(huì)生效:

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

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

          使用JavaScript修復(fù)移動(dòng)設(shè)備上的100vh問(wèn)題

          可以使用 window 的 innerHeight 屬性,將元素 height (或minHeight)設(shè)置為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>

          效果:

          聊聊為什么不應(yīng)該依賴CSS 100vh?

          接著,再介紹一種花銷的方式。 一些開(kāi)發(fā)者喜歡根據(jù)窗口的內(nèi)部高度定義一個(gè)CSS變量,并使用該變量來(lái)設(shè)計(jì)他們所需的元素。代碼如下:

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

          在 CSS 中:

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

          最后一件事是當(dāng)窗口被調(diào)整大小或設(shè)備方向改變時(shí),重新計(jì)算這個(gè)值:

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

          在我看來(lái),你應(yīng)該先用CSS的解決方案。

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

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)