gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

聊聊為什么不應(yīng)該依賴CSS 100vh?

為什么不應(yīng)該依賴CSS 100vh?下面本篇文章就來帶大家聊聊原因,希望對大家有所幫助!

聊聊為什么不應(yīng)該依賴CSS 100vh?

前端(vue)入門到精通課程:進(jìn)入學(xué)習(xí)
API 文檔、設(shè)計、調(diào)試、自動化測試一體化協(xié)作工具:點擊使用

如果有一個文本和一個按鈕,我們想讓文本粘在上面,而按鈕粘在下面!使用CSS Flex 似乎很容易做到。【推薦學(xué)習(xí):css視頻教程】

// 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; }

在真機檢查一下效果:

聊聊為什么不應(yīng)該依賴CSS 100vh?

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

這有什么問題嗎?

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

聊聊為什么不應(yīng)該依賴CSS 100vh?

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

順便說一下,它在安卓手機上甚至不能按預(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 <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)該依賴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類型聲明問題

頁面上有 <!DOCTYPE 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 <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ī)則就不會生效:

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

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

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

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

<!DOCTYPE html> <html> <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>

效果:

聊聊為什么不應(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的解決方案。

(學(xué)習(xí)視頻分享:css視頻教程、web前端)

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
97视频久久久| 又色又爽又高潮免费视频国产| av之家在线观看| 国产精品久久国产| avav在线播放| 欧美人成在线观看| 蜜桃传媒一区二区三区| 国产av天堂无码一区二区三区| 国产精品国产三级国产专区51| 亚洲精品天堂成人片av在线播放 | 午夜探花在线观看| 中文字幕乱码免费| 欧美无砖专区免费| 狠狠干 狠狠操| 色综合av综合无码综合网站| 国产一区视频免费观看| 在线观看日本一区二区| 亚洲天堂网站在线| 浴室偷拍美女洗澡456在线| 久久久成人精品一区二区三区| 午夜啪啪福利视频| 男人靠女人免费视频网站| 美女一区二区三区视频| 亚洲第一成肉网| 免费人成在线观看视频播放| 99爱视频在线| 中文字幕第22页| 日韩在线综合网| 三区视频在线观看| 免费 成 人 黄 色| 久久久精品高清| av高清在线免费观看| 艹b视频在线观看| 亚洲精品蜜桃久久久久久| 簧片在线免费看| 欧妇女乱妇女乱视频| www.久久久精品| 精品少妇一区二区三区在线| 亚洲久久中文字幕| 波多野结衣综合网| 午夜免费视频网站| 亚洲精品乱码久久久久久自慰| 国内精品国产三级国产aⅴ久| 日韩激情免费视频| 51xx午夜影福利| 无尽裸体动漫2d在线观看| 黄色国产一级视频| 成人在线免费高清视频| 在线不卡一区二区三区| 国产精品亚洲a| www..com日韩| 国产美女作爱全过程免费视频| 久久精品影视大全| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 三年中文高清在线观看第6集 | 久久综合久久网| 色网站在线视频| 美女网站色免费| 妺妺窝人体色www在线观看| 国产精品专区在线| 韩日视频在线观看| 欧美黑人在线观看| 男人添女人下部视频免费| 奇米777在线视频| 91视频福利网| 青青草影院在线观看| avove在线观看| 激情图片qvod| 欧美久久久久久久久久久久久久| 中文字幕乱码免费| 国内少妇毛片视频| 国内精品视频一区二区三区| 免费人成自慰网站| 男女私大尺度视频| 国产中文字幕二区| 欧美精品一区二区三区免费播放| 黑人糟蹋人妻hd中文字幕| 草草久久久无码国产专区| 99蜜桃臀久久久欧美精品网站| 可以免费观看av毛片| 国产又大又黄又粗的视频| 日韩成人精品视频在线观看| 日本特级黄色大片| 91精品国产91久久久久麻豆 主演| 99国产精品白浆在线观看免费| 日本香蕉视频在线观看| 18禁男女爽爽爽午夜网站免费| 手机看片福利日韩| 日韩视频在线免费播放| 99久久国产综合精品五月天喷水| 国产97在线 | 亚洲| 久久精品影视大全| 狠狠干视频网站| 精品国产成人av在线免| 手机在线观看日韩av| 国产av麻豆mag剧集| 亚洲另类第一页| av免费观看大全| 午夜精品久久久久久久99热影院| 日韩精品一区二区三区四| 9久久婷婷国产综合精品性色| 特级西西444| 亚洲乱码国产一区三区| 337p亚洲精品色噜噜狠狠p| 久久久国产欧美| 妞干网在线观看视频| 日本中文字幕二区| 久久综合色视频| 国产四区在线观看| 黄色一级二级三级| 亚洲中文字幕无码专区| 成人性做爰片免费视频| 国产精品一区二区小说| 国产人妻777人伦精品hd| 免费网站在线观看黄| 十八禁视频网站在线观看| 国产精品成人久久电影| 日本特级黄色大片| 中文字幕 欧美日韩| 久草精品在线播放| 免费看日本毛片| 少妇大叫太大太粗太爽了a片小说| 国产精品一区二区小说| 黄色片久久久久| 国产视频九色蝌蚪| 欧美亚洲黄色片| 激情成人开心网| 国产一区二区片| 日韩精品综合在线| 国产在线xxxx| 久久av综合网| 99在线免费视频观看| 成人免费在线视频播放| 日韩亚洲欧美一区二区| 欧美日韩午夜爽爽| 国产一级做a爰片久久毛片男| 日本精品免费视频| 青青视频免费在线| av网站手机在线观看| 福利视频一区二区三区四区| 一二三四中文字幕| 日韩 欧美 视频| 欧美日韩激情视频在线观看| 逼特逼视频在线| 欧美日韩第二页| 黄色永久免费网站| 国产又黄又爽免费视频| 男女激烈动态图| 亚洲人成无码网站久久99热国产 | 拔插拔插华人永久免费| 欧美午夜精品理论片| 水蜜桃在线免费观看| 成人免费aaa| 超碰超碰在线观看| 狠狠精品干练久久久无码中文字幕| 久久这里只有精品8| 免费高清在线观看免费| 欧美wwwwwww| 亚洲国产精品无码观看久久| caopor在线视频| 最新中文字幕久久| 国产91在线视频观看| 波多野结衣国产精品| av网站手机在线观看| 午夜免费高清视频| 日韩精品一区在线视频| 久久黄色片网站| 人妻av无码专区| 亚洲va在线va天堂va偷拍| 99久久免费观看| 91视频这里只有精品| 草草久久久无码国产专区| 91日韩精品视频| 97在线免费公开视频| 艳母动漫在线观看| 天天操,天天操| 99色精品视频| 国产精品日韩三级| 91热视频在线观看| 国产又大又硬又粗| www精品久久| 超碰97在线看| 无套内谢丰满少妇中文字幕| 波多野结衣作品集| 亚洲国产精品无码观看久久| 日本中文字幕在线不卡| 亚洲 欧美 另类人妖| 91免费视频网站在线观看| 日韩欧美视频免费在线观看| 992tv人人草| 五月天国产视频| 91 视频免费观看| 亚洲18在线看污www麻豆| 91香蕉视频污版| 一区二区三区入口| 免费看a级黄色片| 亚洲不卡视频在线| www.色偷偷.com| 三上悠亚在线一区二区| 超碰97人人射妻|