日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
不應(yīng)該依賴CSS100vh的原因是什么

今天小編給大家分享一下不應(yīng)該依賴CSS 100vh的原因是什么的相關(guān)知識點,內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

創(chuàng)新互聯(lián)建站是一家專注于成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計與策劃設(shè)計,色尼網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)建站做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:色尼等地區(qū)。色尼做網(wǎng)站價格咨詢:13518219792

如果有一個文本和一個按鈕,我們想讓文本粘在上面,而按鈕粘在下面!使用CSS Flex 似乎很容易做到。

// HTML

  

Lorem ipsum dolor sit amet...

  
// 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!

這有什么問題嗎?

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

不應(yīng)該依賴CSS 100vh的原因是什么

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

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

不應(yīng)該依賴CSS 100vh的原因是什么

為什么100vh問題會發(fā)生在移動設(shè)備上?

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

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

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

// HTML

  

Lorem ipsum dolor sit amet...

  
// 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的原因是什么

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

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

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

.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è)備時,它還會更新高度,太棒了!

不應(yīng)該依賴CSS 100vh的原因是什么

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

1. HTML類型聲明問題

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

不應(yīng)該依賴CSS 100vh的原因是什么

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

不應(yīng)該依賴CSS 100vh的原因是什么

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

2. Safari上的垂直 padding  問題

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

不應(yīng)該依賴CSS 100vh的原因是什么

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

// HTML

  
    ...
  
// 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ī)則就不會生效:

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

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

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

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




  



  

Hello World!

  

The height of this area is equal to...

...

效果:

不應(yīng)該依賴CSS 100vh的原因是什么

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

// 以像素為單位計算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è)備方向改變時,重新計算這個值:

function calculateVh() {
  var vh = window.innerHeight * 0.01;
  document.documentElement.style.setProperty('--vh', vh + 'px');
}

// 初始計算
calculateVh();

// 調(diào)整大小時重新計算
window.addEventListener('resize', calculateVh);

// 在設(shè)備方向改變時重新計算
window.addEventListener('orientationchange', calculateVh);

以上就是“不應(yīng)該依賴CSS 100vh的原因是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


文章名稱:不應(yīng)該依賴CSS100vh的原因是什么
文章地址:http://www.dlmjj.cn/article/ipshhs.html