溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

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

發(fā)布時(shí)間:2022-09-22 09:34:24 來(lái)源:億速云 閱讀:125 作者:iii 欄目:web開(kāi)發(fā)

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

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

// 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)該依賴(lài)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)該依賴(lài)CSS 100vh的原因是什么

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

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

不應(yīng)該依賴(lài)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)該依賴(lài)CSS 100vh的原因是什么

它在橫向模式下也很好:

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

說(shuō)實(shí)話(huà),結(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)該依賴(lài)CSS 100vh的原因是什么

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

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

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

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

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

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

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

不應(yīng)該依賴(lài)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)該依賴(lài)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">
  <h2>Hello World!</h2>
  <h3>The height of this area is equal to...</h3>
</div>
...
<script>
  (function () {
    const el = document.getElementById('intro');
    el.style.minHeight = window.innerHeight + 'px';
  })();
</script>
</body>
</html>

效果:

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

接著,再介紹一種花銷(xiāo)的方式。 一些開(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);

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

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI