国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

你不應該依賴CSS 100vh,這就是原因!

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

如果有一個文本和一個按鈕,我們想讓文本粘在上面,而按鈕粘在下面!使用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;
}

在真機檢查一下效果:

圖片

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

這有什么問題嗎?

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

圖片

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

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

圖片

為什么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;
}

效果:

圖片

它在橫向模式下也很好:

圖片

說實話,結果是好的,但你不能總是用 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;
}

效果:

圖片

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

圖片

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

1. HTML類型聲明問題

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

圖片

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

圖片

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

2. Safari上的垂直 padding  問題

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

圖片

要解決這個問題,只需將你的內容包在另一個 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 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>

效果:

圖片

接著,再介紹一種花銷的方式。一些開發者喜歡根據窗口的內部高度定義一個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的解決方案。

作者:Mehdi Namvar  

譯者:前端小智

來源:mediun

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

責任編輯:武曉燕 來源: 大遷世界
相關推薦

2022-03-09 08:14:24

CSS容器container

2020-06-05 14:09:42

Kubernetes容器應用程序

2025-05-23 10:19:14

2009-01-03 15:07:38

ibmdwAIX

2013-05-29 10:10:05

醫療搜索互聯網大數據

2022-05-31 12:26:50

移動響應css

2025-05-07 00:00:00

CSS單位JavaScript

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

云計算云端企業

2022-04-20 20:47:35

圖像壓縮鴻蒙操作系統

2023-04-04 08:10:40

CSS字體元素

2020-03-25 07:14:36

預測性維護工業物聯網IIOT

2020-06-17 10:35:16

機器學習AI人工智能

2020-06-21 21:25:14

物聯網WiFiIOT

2018-11-20 14:03:17

數據科學數據分析數據科學家

2016-10-12 16:34:37

Linux操作系統

2019-09-02 09:30:40

點贊
收藏

51CTO技術棧公眾號

粉嫩一区二区三区在线看| 四虎精品永久免费| 亚洲欧美在线专区| 337p亚洲精品色噜噜狠狠| 亚洲制服中文| 久久69av| 日韩丝袜美女视频| av天天在线| 国产主播一区二区三区| 成人a在线视频| 日韩性xxx| 欧美日韩午夜在线视频| 黄色手机在线视频| 免费在线日韩av| 人妖精品videosex性欧美| 婷婷av在线| 一区二区三区中文字幕电影 | 国产精品美女视频| 亚洲日本精品| 欧美日一区二区| 久久久久久999| 色综合一本到久久亚洲91| 伊是香蕉大人久久| 国产精品无码久久久久| 影音先锋日韩有码| 91成人高清| 日韩欧美在线网址| 偷拍自拍在线视频| 亚洲欧美日韩国产手机在线| 桥本有菜av在线| 国产亚洲一级| 亚洲精品一卡二卡三卡四卡| 欧美亚洲一级| 8x8x华人在线| 偷拍视频一区二区| 国内在线视频| 欧美视频一区二区在线观看| jizz一区二区三区| 欧美肥婆姓交大片| 精品国模一区二区三区| 欧美刺激午夜性久久久久久久| 日本天堂在线| 91麻豆精品国产自产在线观看一区| 亚欧无线一线二线三线区别| 国产成人综合在线观看| 色网在线视频| 国产精品日韩一区二区| 成人av资源在线观看| 天堂中文字幕在线| 隔壁老王国产在线精品| 日韩av一区二区在线影视| 精品中文字幕人| 最好看的中文字幕久久| 很黄的网站在线观看| 中文字幕字幕中文在线中不卡视频| 日本精品在线视频| 九九九在线观看视频| 国产婷婷色一区二区三区在线| 精品一区二区在线观看| 日本高清不卡三区| 韩国三级在线一区| 国产a级片网站| 中文字幕av资源一区| 男女人搞j网站| 午夜伦理一区二区| 日韩伦理在线电影| 日韩精品视频免费专区在线播放 | 久久精品国产免费| 人人妻人人澡人人爽精品欧美一区| 老司机午夜精品99久久| 屁屁影院ccyy国产第一页| 国产亚洲综合在线| 在线观看免费av网| 欧美精品九九99久久| 欧美日韩精品免费观看视欧美高清免费大片| 中文字幕无线精品亚洲乱码一区| 亚洲天堂av资源在线观看| 国产精品麻豆va在线播放| 国产一级一区二区| 亚洲国产精品无码观看久久| 欧美经典一区二区| 国产一二三在线观看| 亚洲男人天堂2023| 99视频在线播放| 高h视频在线观看| 国产视频精品va久久久久久| 日本在线成人| 成人永久免费| 91日韩在线专区| 毛片免费在线观看| 在线播放国产一区二区三区| 日韩欧美黄色| 亚洲国产日韩综合一区| 国产精品毛片久久久久久久| 污网站免费在线观看| 日韩欧美精品在线| 国产美女撒尿一区二区| 久久riav二区三区| 中文字幕一区二区三中文字幕| av大全在线| 国产成人精品午夜| 国产麻豆一精品一av一免费| 一二三四中文在线| 亚洲欧美综合图区| 99成人超碰| 天堂中文视频在线| 日韩一区二区精品葵司在线| 欧美变态挠脚心| 色一情一乱一乱一区91| 日韩欧美中文第一页| 国产一区二区三区国产精品| 欧美极品一区二区| 一区二区三区波多野结衣在线观看 | 国产91成人video| 国产在线精品一区二区夜色| 久草影视在线| 久久综合88中文色鬼| 国产亚洲一级| 日韩黄色影片| 热99久久精品| 久久久五月婷婷| 搞黄网站在线看| 国产精品视频福利| 艳妇臀荡乳欲伦亚洲一区| 快播电影网址老女人久久| 国产精品视频入口| 亚洲图片你懂的| 国产精品xnxxcom| 欧美少妇一区二区三区| 欧美精品亚洲一区二区在线播放| 免费观看久久av| 免费在线观看毛片网站| 日韩精品极品在线观看| 久久久久久亚洲精品杨幂换脸| 亚洲最新合集| 日av在线播放中文不卡| 国产午夜亚洲精品羞羞网站| 综合毛片免费视频| 综合视频免费看| 精品免费日韩av| 久久久国产亚洲精品| 高清在线观看av| 国产精品久久综合av爱欲tv| 国产精品欧美精品| 亚洲国产高清在线观看| 久久99久久久久久| 亚洲欧美在线免费观看| 秋霞午夜av一区二区三区| 快射av在线播放一区| 97久久精品午夜一区二区| 亚洲国产aⅴ成人精品无吗| 久久久免费毛片| 久热精品在线播放| 久久久久久久电影一区| 久久精品人人做| 国产毛片精品| 肥女人的一级毛片| 青草青草久热精品视频在线观看| 国产精品久99| 深爱激情综合| 91嫩草在线播放| 亚洲va久久久噜噜噜| 日本道在线观看一区二区| 精品av久久久久电影| 黄色免费在线观看| 一区二区三区不卡在线| 亚洲深夜福利视频| 久久精品免费在线观看| 美女午夜精品| 最近中文字幕在线| 国产无套精品一区二区| 欧美tickling网站挠脚心| 精品中文字幕一区二区| 欧美97人人模人人爽人人喊视频| 日本成人黄色网| 国产精品成久久久久三级 | 欧美aaa在线观看| 在线观看日韩视频| 国产人久久人人人人爽| 九九久久电影| yiren22综合网成人| 色一情一乱一伦一区二区三欧美| 亚洲精品一区中文字幕乱码| 94色蜜桃网一区二区三区| 久久精品国产亚洲5555| 91欧洲在线视精品在亚洲| 不卡一卡2卡3卡4卡精品在| 日韩精品综合一本久道在线视频| 国产精品一区二区久久不卡| 国产精品自在| 美女欧美视频在线观看免费| 神马影院我不卡| 日韩在线免费av| 亚洲精品第一国产综合野| 亚洲国产专区| 成人在线不卡| 青青草在线免费视频| 亚洲视频在线二区| 欧美亚洲在线视频| 日韩午夜av电影|