自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

你不應(yīng)該依賴CSS 100vh,這就是原因!

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

如果有一個(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ī)檢查一下效果:

圖片

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

這有什么問題嗎?

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

圖片

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

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

圖片

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

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

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

第一個(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;
}

效果:

圖片

它在橫向模式下也很好:

圖片

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

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

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

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

效果:

圖片

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

圖片

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

1. HTML類型聲明問題

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

圖片

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

圖片

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

2. Safari上的垂直 padding  問題

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

圖片

要解決這個(gè)問題,只需將你的內(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問題

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

<!DOCTYPE html>
<html lang="en">
<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>

效果:

圖片

接著,再介紹一種花銷的方式。一些開發(fā)者喜歡根據(jù)窗口的內(nèi)部高度定義一個(gè)CSS變量,并使用該變量來設(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)該先用CSS的解決方案。

作者:Mehdi Namvar  

譯者:前端小智

來源:mediun

原文:https://ilxanlar.mdium.com/you-shouldnt-relyon-css-100vh-and-here-s-why-1b4721e74487?

責(zé)任編輯:武曉燕 來源: 大遷世界
相關(guān)推薦

2022-03-09 08:14:24

CSS容器container

2020-06-05 14:09:42

Kubernetes容器應(yīng)用程序

2009-01-03 15:07:38

ibmdwAIX

2013-05-29 10:10:05

醫(yī)療搜索互聯(lián)網(wǎng)大數(shù)據(jù)

2022-05-31 12:26:50

移動(dòng)響應(yīng)css

2018-09-28 16:17:20

Java 11升級Oracle

2023-08-01 08:18:09

CSSUnset

2022-07-03 08:14:30

VS Code主題

2023-03-24 12:52:22

2019-04-04 14:33:19

云計(jì)算云端企業(yè)

2022-04-20 20:47:35

圖像壓縮鴻蒙操作系統(tǒng)

2023-04-04 08:10:40

CSS字體元素

2020-03-25 07:14:36

預(yù)測性維護(hù)工業(yè)物聯(lián)網(wǎng)IIOT

2020-06-21 21:25:14

物聯(lián)網(wǎng)WiFiIOT

2020-06-17 10:35:16

機(jī)器學(xué)習(xí)AI人工智能

2018-11-20 14:03:17

數(shù)據(jù)科學(xué)數(shù)據(jù)分析數(shù)據(jù)科學(xué)家

2016-10-12 16:34:37

Linux操作系統(tǒng)

2022-07-28 13:11:45

箭頭函數(shù)前端代碼

2020-05-06 15:15:33

Python開發(fā)工具

2010-07-05 14:47:26

Gartner社交網(wǎng)絡(luò)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號