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è)計(jì)、調(diào)試、自動(dòng)化測試一體化協(xié)作工具:點(diǎn)擊使用

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

在真機(jī)檢查一下效果:

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

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

這有什么問題嗎?

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

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

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

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

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

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

我對這個(gè)問題進(jìn)行了一番調(diào)查,發(fā)現(xiàn)了其中的原因。簡短的答案是,瀏覽器的工具欄高度沒有被考慮在內(nèi)。如果你想深入了解為什么會發(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; }

效果:

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

它在橫向模式下也很好:

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

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

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

時(shí),使用 vh 的目的是為了簡單地創(chuàng)建與視口高度相等的部分。例如,當(dāng)你在建立登陸頁面時(shí),這很常見。在這些情況下,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è)備時(shí),它還會更新高度,太棒了!

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

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

1. HTML類型聲明問題

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

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

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

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

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

2. Safari上的垂直 padding 問題

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

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

要解決這個(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ī)則就不會生效:

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

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

使用JavaScript修復(fù)移動(dòng)設(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)部高度定義一個(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的解決方案。

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

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
欧美三级午夜理伦三级| 大胆欧美熟妇xx| 欧洲美女亚洲激情| www.污污视频| 可以在线看黄的网站| 国产午夜大地久久| 三级视频中文字幕| 久久亚洲a v| 国产一线二线三线在线观看| 国产视频1区2区3区| 97超碰在线视| 一级片免费在线观看视频| 欧美国产日韩在线视频 | 在线观看三级网站| 91国产精品视频在线观看| 日韩精品一区二区三区电影| 国产视频九色蝌蚪| 欧美又粗又长又爽做受| 在线成人免费av| a在线观看免费视频| 丁香花在线影院观看在线播放| 午夜不卡福利视频| 久久久久xxxx| 污污视频网站在线| 在线看的黄色网址| 日韩欧美理论片| 中文字幕66页| 亚洲AV无码成人精品一区| 亚洲精品久久久久久宅男| 国产一二三区av| 精品久久久99| 久久综合亚洲精品| 欧美 日韩 亚洲 一区| 已婚少妇美妙人妻系列| 国产九九在线视频| 三年中文高清在线观看第6集| 日本三级黄色网址| 91视频福利网| 日本va中文字幕| 污视频在线观看免费网站| 国产高清不卡无码视频| 熟妇人妻va精品中文字幕| 在线免费看v片| 免费国产黄色网址| 亚洲综合123| 爆乳熟妇一区二区三区霸乳| 国产精品中文久久久久久| 成人午夜免费在线| 日本熟妇人妻xxxx| 1314成人网| 天天看片天天操| 亚洲污视频在线观看| av免费看网址| 国产精品网站免费| 国产一区二区三区乱码| 五月天男人天堂| 污免费在线观看| 污视频网址在线观看| 五月婷婷丁香色| 手机av在线网| 国产欧美综合一区| 老汉色影院首页| 黄色成人免费看| 国产精品一区二区小说| chinese少妇国语对白| 久久国产乱子伦免费精品| 玩弄中年熟妇正在播放| 色综合av综合无码综合网站| 青青草原成人网| 欧美激情第一区| 大荫蒂性生交片| aaaaaa亚洲| 亚洲一区二区三区四区精品| 亚洲成人动漫在线| 麻豆av免费在线| 午夜av中文字幕| 日本在线xxx| 午夜激情影院在线观看| 97在线国产视频| 91插插插影院| 日本成人在线免费视频| 久久久久久久9| 欧美精品久久久久久久久25p| 黄色影视在线观看| 天天插天天操天天射| 国产精品69久久久| 懂色av一区二区三区四区五区| 伊人免费视频二| 欧美aaa在线观看| 国产一伦一伦一伦| 无码aⅴ精品一区二区三区浪潮| 亚洲精品mv在线观看| 亚洲色欲综合一区二区三区| 国产精品国三级国产av| 97超碰人人爱| 999一区二区三区| 婷婷激情综合五月天| 中日韩av在线播放| 午夜免费看视频| 亚洲综合在线一区二区| 在线观看亚洲色图| 欧美伦理片在线观看| 亚洲欧美日韩综合网| 无码人妻丰满熟妇区96| 九色在线视频观看| 婷婷六月天在线| 自拍一级黄色片| 九九爱精品视频| 五月婷婷六月合| 国产精品久久中文字幕| 黄色一级大片在线观看| 老汉色影院首页| 男人插女人下面免费视频| 亚洲激情在线观看视频| 日韩视频在线视频| 国产系列第一页| 成人免费在线观看视频网站| 欧美一区二区激情| 成年人黄色在线观看| 无码精品国产一区二区三区免费| 中文字幕资源在线观看| 天天操天天爽天天射| 中文字幕 日韩 欧美| 可以免费观看av毛片| 日韩精品在线视频免费观看| 人人爽人人爽av| 在线看免费毛片| 欧美精品性生活| 看欧美ab黄色大片视频免费| www黄色日本| 超碰97人人射妻| 欧美精品一区二区三区免费播放| 国产特级黄色大片| 精品欧美一区免费观看α√| 精品人妻少妇一区二区| www.xxx麻豆| 日本熟妇人妻xxxxx| 欧美一级特黄a| 日本一区二区三区四区五区六区| 亚洲一区二区偷拍| 好吊色视频988gao在线观看| 黄色网zhan| 欧美日韩在线成人| 亚洲 欧洲 日韩| 妺妺窝人体色www在线小说| av丝袜天堂网| 性高湖久久久久久久久aaaaa| 无码内射中文字幕岛国片| 天天看片天天操| 久久无码高潮喷水| 国产高潮呻吟久久久| 午夜免费福利在线| 欧美视频在线观看视频| 黄色片免费网址| 手机在线看福利| 日韩人妻精品无码一区二区三区| 天天综合网久久| 日韩视频在线免费看| 亚洲 欧美 综合 另类 中字| 日本国产一级片| 日本一二区免费| 日韩一区二区三区久久| 国内自拍在线观看| 国产成人一区二区三区别| 国产探花在线观看视频| 亚洲日本黄色片| 亚洲免费av网| 黑人巨大国产9丨视频| 日本成人性视频| 欧美精品在欧美一区二区| 99re6这里有精品热视频| av磁力番号网| 国产精品无码av在线播放| 无码 制服 丝袜 国产 另类| 狠狠97人人婷婷五月| 毛片一区二区三区四区| 欧美激情第一区| 黄色三级中文字幕| 国产xxxxx视频| 欧美 国产 精品| 粗暴91大变态调教| 久久精品一二三四| 国产成人无码一二三区视频| 在线视频观看91| 999精品网站| 天堂8在线天堂资源bt| 日韩一区二区三区久久| 无码人妻少妇伦在线电影| 激情视频免费网站| aa免费在线观看| 欧美黄色免费网址| 日本高清久久久| 男人的天堂日韩| 蜜臀久久99精品久久久酒店新书| 久久久一二三四| 国产91av视频在线观看| 99re精彩视频| 手机版av在线| 91热视频在线观看| 尤物国产在线观看|