精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

你不應該依賴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容器應用程序

2009-01-03 15:07:38

ibmdwAIX

2013-05-29 10:10:05

醫療搜索互聯網大數據

2025-05-23 10:19:14

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主題

2022-05-31 12:26:50

移動響應css

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

2018-11-20 14:03:17

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

2020-06-17 10:35:16

機器學習AI人工智能

2020-06-21 21:25:14

物聯網WiFiIOT

2016-10-12 16:34:37

Linux操作系統

2020-05-06 15:15:33

Python開發工具
點贊
收藏

51CTO技術棧公眾號

日韩性感在线| 热久久美女精品天天吊色| 91热视频在线观看| 日本小视频在线免费观看| 不卡电影一区二区三区| 国产成人自拍视频在线观看| 网爆门在线观看| 日韩三级精品| 欧美性黄网官网| 成人短视频在线看| 天天爱天天干天天操| 国产精品免费看| 久久久精品国产一区二区| av无码一区二区三区| 亚洲电影二区| 色综合一区二区| 日韩最新中文字幕| 狠狠v欧美ⅴ日韩v亚洲v大胸 | 九九精品在线观看| 国产精品无码电影| 精品国产亚洲一区二区在线观看| 欧美日韩午夜剧场| 少妇久久久久久被弄到高潮| 风间由美一区| 久久综合999| 超碰在线97av| 6—12呦国产精品| 视频一区欧美日韩| 韩国精品美女www爽爽爽视频| 蜜桃视频最新网址| 国产成人短视频在线观看| 日韩免费在线观看| 久久成年人网站| 巨胸喷奶水www久久久免费动漫| 午夜精品免费在线| 毛片av在线播放| 国产色在线观看| 国产精品美女久久久久av爽李琼| 麻豆传媒一区二区| 无码国产伦一区二区三区视频| 国产精品一卡二卡在线观看| 国产精品亚洲аv天堂网| 四虎成人永久免费视频| 在线精品福利| 久久人人爽国产| 九九热视频精品| 91精品国产调教在线观看| 一区二区三区在线播放欧美| 亚洲一区视频在线播放| 中文字幕av一区二区三区人| 亚洲精品美女久久久久| 国产精品九九视频| 69精品国产久热在线观看| 日韩欧美国产午夜精品| 欧美性猛交乱大交| 精品精品视频| 欧美成人一区二区三区在线观看| 深夜做爰性大片蜜桃| 精品亚洲a∨一区二区三区18| 欧美剧在线免费观看网站| 中文字幕免费高清在线| 四虎精品永久免费| 911精品国产一区二区在线| 999在线观看| 日韩有码欧美| 91精品中文字幕一区二区三区| 一级日本黄色片| 视频在线一区| 亚洲电影免费观看| 精品久久久久久中文字幕人妻最新| 日韩理论电影中文字幕| 亚洲欧洲在线免费| 女人裸体性做爰全过| 久久精品久久久| 九九热这里只有精品免费看| 久久精品视频久久| 欧美综合二区| 国产日韩欧美日韩| 亚洲第一成年人网站| 99精品视频一区二区| 欧美第一黄网| 日本三级视频在线播放| 一区二区三区国产精品| 丝袜老师办公室里做好紧好爽 | 在线观看av黄网站永久| 亚洲欧美一区二区三区久本道91| 国产精品无码电影在线观看| 深夜av在线| 欧美日韩在线直播| 丰满少妇中文字幕| 要久久爱电视剧全集完整观看| 国产一区二区三区在线看 | 精品成人国产在线观看男人呻吟| 国产99久久九九精品无码| av在线一区不卡| 精品伦理精品一区| 性欧美一区二区| 欧美福利网址| 国产精品免费久久久久久| 国产99久一区二区三区a片| 99视频一区二区| 亚洲日本精品| 美女高潮视频在线看| 欧美亚洲国产一区二区三区va | 亚洲熟妇av乱码在线观看| 国产91在线观看| 五月天亚洲综合情| 超级碰碰不卡在线视频| 欧美人伦禁忌dvd放荡欲情| 无码人妻精品一区二区三区99不卡| 狠狠色狠狠色综合婷婷tag| 欧美极品欧美精品欧美视频 | 国产精品白丝jk黑袜喷水| 免费久久久一本精品久久区| 黄色网在线免费看| 91成人免费网站| 污污免费在线观看| 欧美/亚洲一区| 国产精品久久久久福利| 欧美一区二区黄片| 亚洲色图欧美偷拍| 一区二区三区 日韩| 欧美成人基地| 欧美国产乱视频| 一区二区不卡视频在线观看| xf在线a精品一区二区视频网站| 自拍偷拍一区二区三区| 日本欧美韩国| 亚洲欧美在线免费观看| 国产女同在线观看| 成人永久看片免费视频天堂| 欧美日韩一区二区三区电影| 欧美成人家庭影院| 在线日韩第一页| 91精品国产高清一区二区三密臀| av影院午夜一区| 欧美日韩不卡在线视频| 国产一区 二区| 日韩午夜在线视频| 影音先锋国产在线| 欧美激情一区二区| 超碰在线97免费| 欧美亚洲在线日韩| 国产精品久久综合av爱欲tv| 国产中文字幕在线看| 日韩欧美亚洲成人| 国产精品无码一区二区三区免费 | 91久久国产| 成人国内精品久久久久一区| 1769视频在线播放免费观看| 欧美性猛片aaaaaaa做受| 丰腴饱满的极品熟妇| 久久一区中文字幕| 日韩高清国产精品| 国产高清不卡| 中文字幕欧美精品日韩中文字幕| 黄色av网站免费| 欧美国产在线观看| 国产福利在线免费| 欧美一区91| 成人精品一二区| 丰满的护士2在线观看高清| 亚洲精品福利免费在线观看| 久久免费激情视频| 久久久精品一品道一区| 午夜精品在线免费观看| 91麻豆国产自产在线观看亚洲 | 国产乱淫a∨片免费视频| 中文字幕亚洲欧美在线不卡| 日本成人xxx| 亚洲精品字幕| 亚洲精品在线视频观看| 国产在线一区不卡| 国内精久久久久久久久久人| 午夜影院免费视频| 欧美在线啊v一区| 男人在线观看视频| 成人午夜视频网站| 成人一区二区三| 自产国语精品视频| 久久福利电影| 日韩一级特黄| 高清欧美电影在线| xxxxx日韩| 精品少妇一区二区三区在线视频| 欧美三级一区二区三区| 国产精品色噜噜| 少妇伦子伦精品无吗| 美女精品一区| mm131午夜| 亚洲色图丝袜| 亚洲一区二区免费在线| 久久毛片亚洲| 欧美成人精品影院| 欧洲亚洲精品视频| 日韩一级片在线播放| 黄色av一级片| 一区二区三区在线免费观看| 成年人免费观看视频网站| 国产激情视频一区二区在线观看| 久久精品免费一区二区| 91综合在线| 欧美精品成人一区二区在线观看| 久久久国产精品入口麻豆| 青青a在线精品免费观看| 午夜在线激情影院| 一区三区二区视频| 天天爽夜夜爽夜夜爽| 欧美乱妇23p| 免费看污视频的网站| 亚洲午夜影视影院在线观看| 成人三级视频在线观看| 91蜜桃在线免费视频| 亚洲欧美激情一区二区三区| 日本在线不卡一区| 黄色免费视频大全| 亚洲视频碰碰| 欧美一级特黄aaaaaa在线看片| 国产午夜一区| 精品国产aⅴ麻豆| 日韩在线观看一区二区三区| 国产精品香蕉国产| 性欧美videohd高精| 97在线视频免费| 超碰在线caoporen| 综合国产在线视频| 国产一区电影| 亚洲欧美三级伦理| 少妇精品视频一区二区| 精品国产三级a在线观看| av一级黄色片| 91精品国产欧美一区二区18| 亚洲天堂网在线视频| 欧美性感一区二区三区| 日本黄色一级视频| 色综合久久久久久久| 欧美bbbbbbbbbbbb精品| 亚洲高清免费在线| 国产一级片网址| 亚洲最色的网站| 精品99在线观看| 亚洲精品大片www| 欧美精品色哟哟| 亚洲蜜桃精久久久久久久| 成人涩涩小片视频日本| 一区在线播放视频| 日韩成人短视频| 亚洲精品一二三| 五月天丁香激情| 亚洲综合在线视频| 18精品爽视频在线观看| 亚洲一二三四在线观看| 久久精品女人毛片国产| 香蕉影视欧美成人| 天天做天天爱夜夜爽| 欧美日韩一区二区三区| 日本久久综合网| 欧洲精品中文字幕| 亚洲系列在线观看| 欧美一区二区在线观看| 国产黄a三级三级三级| 精品捆绑美女sm三区| 四虎精品成人免费网站| 亚洲色图第三页| 婷婷免费在线视频| 欧美精品生活片| 2018av在线| 国产ts一区二区| 欧洲亚洲精品久久久久| 亚洲尤物视频网| 久久影院资源站| 欧美一区三区二区在线观看| 日本精品三区| 欧美 亚洲 视频| 国产精品毛片一区二区三区| 高清一区二区视频| 国产精品一色哟哟哟| 无码人妻精品一区二区三| 91麻豆精品视频| 一本一本久久a久久| 亚洲综合男人的天堂| 欧美激情黑白配| 欧美美女喷水视频| 人妻一区二区三区四区| 亚洲少妇激情视频| 在线三级电影| 日韩av电影手机在线| 视频一区在线| 日日骚一区二区网站| 激情视频一区二区三区| 欧美日韩大尺度| 国产福利精品导航| 无码人妻丰满熟妇啪啪欧美| 亚洲乱码国产乱码精品精的特点| 九一国产在线观看| 91麻豆精品国产91久久久久久久久| 天天综合网天天综合| 精品国产一区二区在线| 三妻四妾完整版在线观看电视剧| 国产精品中文字幕在线观看| 成人午夜大片| 这里只有精品66| 久久国产精品久久w女人spa| 国模大尺度视频| 中文字幕二三区不卡| 日韩精品无码一区二区| 91麻豆精品国产| 超碰免费97在线观看| 91国内在线视频| 伊色综合久久之综合久久| 视频三区二区一区| 国产精品日韩| 亚洲精品成人无码毛片| 国产精品久久久久久久久久久免费看 | www.成人.com| 69久久夜色精品国产69| 欧美视频二区欧美影视| 五月天综合网| 久久最新视频| 亚洲第一成人网站| 五月天丁香久久| 亚洲毛片欧洲毛片国产一品色| 最近免费中文字幕视频2019| 婷婷六月国产精品久久不卡| 国产精品免费一区二区三区在线观看 | 成人免费精品视频| av成人免费网站| 欧美日韩精品是欧美日韩精品| 伦理片一区二区三区| 91高清视频在线免费观看| av一级亚洲| 国产情侣第一页| 国产传媒久久文化传媒| 国产午夜精品理论片| 欧美私人免费视频| 97视频在线观看网站| 国产精品久久久久久久一区探花 | 成人av资源站| 精品午夜福利在线观看| 精品三级在线看| 日韩精品亚洲人成在线观看| 亚洲一区二区三区久久| 88国产精品视频一区二区三区| 天天综合天天添夜夜添狠狠添| 国产精品女同一区二区三区| 国产精品欧美综合| 国产亚洲福利一区| 日韩制服一区| 亚洲欧洲久久| 激情五月婷婷综合| 欧美日韩亚洲国产另类| 精品国产免费人成电影在线观看四季 | 亚洲国产成人一区二区三区| 中文字幕在线观看你懂的| 色阁综合伊人av| 国产精品3区| 日本wwwcom| 91蝌蚪porny| 成人免费毛片男人用品| 在线电影欧美日韩一区二区私密| 欧美日韩视频免费看| 男女h黄动漫啪啪无遮挡软件| 国产乱人伦偷精品视频免下载| 91嫩草|国产丨精品入口| 日韩欧美亚洲另类制服综合在线| 久久青青色综合| 蜜桃成人在线| 热久久免费视频| 男人av资源站| 精品国产一二三区| 日韩国产激情| 色乱码一区二区三区熟女| 国产成人aaaa| 久久久久久久久黄色| www.亚洲天堂| 欧美绝顶高潮抽搐喷水合集| 亚洲免费看av| 亚洲一区av在线| 国产片在线观看| 成人在线一区二区| 在线看片一区| 中文字幕伦理片| 欧美成人精品1314www| 亚洲欧美se| 自拍偷拍一区二区三区| www.亚洲免费av| 最新黄色网址在线观看| 欧美高跟鞋交xxxxxhd| 亚洲精品白浆高清| 亚洲天堂av一区二区| 黄色成人在线播放| 日本三级视频在线播放| 久久精品第九区免费观看 | 亚洲在线第一页| 一本色道久久综合| 五月综合色婷婷| 精品中文字幕久久久久久| 国产精品va视频| 最近免费中文字幕中文高清百度| 一区二区在线观看免费|