成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

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

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

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

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

前端(vue)入門到精通課程:進(jìn)入學(xué)習(xí)
API 文檔、設(shè)計(jì)、調(diào)試、自動(dòng)化測(cè)試一體化協(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)行測(cè)試,下面是結(jié)果:

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

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

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

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

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

我對(duì)這個(gè)問題進(jìn)行了一番調(diào)查,發(fā)現(xiàn)了其中的原因。簡(jiǎ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; }

效果:

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

它在橫向模式下也很好:

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

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

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

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

.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í),它還會(huì)更新高度,太棒了!

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

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

1. HTML類型聲明問題

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

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

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

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

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

2. Safari上的垂直 padding 問題

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

聊聊為什么不應(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ī)則就不會(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> <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變量,并使用該變量來(lái)設(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);

在我看來(lái),你應(yīng)該先用CSS的解決方案。

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

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
国产AV一区二区三区日韩| 蜜臀亚洲AV无码精品国产午夜.| 国产成人无码AV在线影院 | 亚洲AV无码国产一区二区三区 | 国精无码欧精品亚洲一区| 精品久久8X国产免费观看| 麻豆极品JK丝袜自慰喷水久久 | 色综合伊人色综合网站| 亚洲 日韩 另类 制服 无码| 亚洲色偷偷综合亚洲AV伊人| 在线人成视频播放午夜福利| ぱらだいす天堂中文网WWW在线| 公交车大龟廷进我身体里| 国产亚洲色欲色一色WWW| 久久亚洲私人国产精品VA| 欧亚激情偷乱人伦小说专区| 四虎免费影院1515WWW| 亚洲AV无码成人精品区在线播放 | 无码专区亚洲综合另类| 亚洲人色婷婷成人网站在线观看| 中文日产幕无限码一区有限公司| JEALOUSVUE成熟| 国产精品免费AV片在线观看| 激情综合婷婷丁香五月俺来也| 鲁死你AV资源站| 日韩精品东京热无码视频| 亚洲AV无码专区国产乱码DVD| 中文字幕丰满乱孑伦无码专区| 成在线人午夜剧场免费无码| 国内揄拍高清国内精品对白| 免费高清曰韩仑理| 天天澡天天添天天摸97影院| 亚洲真人无码永久在线观看| 把腿张开老子cao烂你n视频| 国产制服丝袜在线无码| 女狠狠噜天天噜日日噜| 天天澡夜夜澡人人澡| 中国A级毛片免费| 国产SUV精品一区二区883| 久久精品亚洲精品无码| 日韩国产女人久久久| 亚洲风情亚Aⅴ在线发布| 99精品国产兔费观看久久| 国产成人久久精品流白浆| 狼友AV永久网站在线观看| 日日碰狠狠添天天爽| 亚洲一区二区自偷自拍另类| VODAFONEWIFI暴力| 精品九九人人做人人爱| 日韩无人区码卡二卡3卡2022| 亚洲女同成AV人片在线观看| 边摸边吃奶又黄又激烈视频| 综合偷自拍亚洲乱中文字幕| 99久久久无码国产精品秋霞网| 国产精品国产三级国产AV剧情| 久久AV无码ΑV高潮ΑV喷吹| 人人人爽人人澡人人高潮| 亚洲精品第一国产综合麻豆 | 国产精品VA在线观看无码不卡| 村长你的机巴太粗太长了| 精品亚洲AV无码喷奶水A漫画| 人妻 中文无码 中出| 亚洲精品无码久久久久去Q| 厨房征服丰满熟妇在线观看| 和岳每晚弄的高潮嗷嗷叫视频| 全免费A敌肛交毛片免费| 亚洲欧美中文日韩V在线观看| 成人毛片100部免费看| 老赵揉搓苏清雅双乳| 亚洲AⅤ永久无码中文字幕| 成年免费A级毛片无码| 久久久精品人妻人人澡| 我故意没有穿内裤坐公车让| A级毛片毛片免费观看久潮喷| 狠狠色丁香婷婷亚洲综合| 色在线 | 国产| A级国产乱理伦片在线观看| 久久99久久99小草精品免视看 | S货叫大声点C懒烂你的SBXS| 精品久久久久久无码专区不卡| 日日摸夜夜添夜夜添亚洲女人| 中文字幕久久熟女蜜桃| 精品人妻一区二区三区三区换着玩 | 国产精品高潮呻吟爱久久AV无码 | 激情综合亚洲色婷婷五月| 私人影院播放器大全| 啊灬啊灬啊灬快灬深视频无遮掩 | 琴乳液狂飙却被空吸入口中| 野花韩国日本高清免费5| 国产毛多水多高潮高清| 搡老女人老妇老熟女hd| AV无码国产在线看免费网站| 看着领导挺进娇妻的体内电影| 亚洲AV永久纯肉无码精品wwt| 公和熄小婷乱中文字幕| 人妻少妇精品久久久久久0000 | 亚洲AV日韩AV高潮喷无码| 公交车大龟廷进我身体里视频 | YY8840私人影院爱不停下载| 麻豆国产成人AV在线播放欲色| 亚洲女人天堂成人AV在线| 国语自产精品视频在线区| 亭亭玉立国色天香四月天| 多毛小姐BGMBGMBGM| 日本适合十八岁以下的护肤| CHINESE国产XXXX实拍| 男女啪啪无遮挡免费网站| 真实国产乱人伦在线视频播放| 精品AV综合一区二区三区| 亚洲AV伊人久久综合密臀性色| 国产热A欧美热A在线视频 | 国产边做边吃奶AⅤ视频免费| 日韩精品无码一区二区三区不卡 | 国产精品边做奶水狂喷无码| 色天使色偷偷色噜噜噜| 成年午夜无码AV片在线观看| 人妻少妇精品无码专区二区| Z0ZOZ0另类Z0ZO| 热RE99久久精品国产99热| WC女厕撒尿七Ⅴ偷拍| 人妻人人澡人人添人人爽人人玩 | 强奷漂亮少妇高潮麻豆| JAPANESE军人强迫| 欧美激情精品久久| MD豆传媒一二三区进站口在线看 | 黑巨人与欧美精品一区| 亚洲成AV人片一区二区小说| 皇上撞着小公主的小说叫什么| 亚洲AV永久无码精品主页| 国产综合久久久久久鬼色| 无码少妇一区二区三区免费| 国产精品天干天干综合网| 香蕉久久一区二区不卡无毒影院 | 久久99国产精品久久99蜜桃| 野花日本中文免费完整版4| 老公朋友东西好大| 又爽又黄又无遮挡的视频在线观看| 久久99精品久久久久久久久久| 亚洲精品卡一卡三卡四卡乱码| 久久99精品国产麻豆宅宅| 亚洲一级无码av毛片www| 两性午夜刺激性视频2345| 99久久99久久免费精品小说| 人妻无码不卡中文字幕在线视频| 粗大的内捧猛烈进出小视频| 铜铜铜铜铜铜铜好-深色| 国精产品一区一区三区| 亚洲人精品午夜射精日韩| 麻豆久久亚洲AV成人无码电影| 99国精产品灬源码168| 日本丰满人妻HD浓毛| 高H日本视频一区| 亚洲AV香蕉一区区二区三区| 久久久久波多野结衣高潮| 97人妻碰碰视频免费上线| 日韩产品和欧美产品的区别| 中国人妻被两个老外三P| 无码中文字幕AⅤ精品影院| 国产无遮挡又黄又爽不要VIP网 | 中文字幕人妻丝袜成熟乱九区| 你的婚礼免费观看完整版| 啊轻点灬大JI巴太粗太长在线了 | 成在人线AV无码免费高潮水老板| 玩弄少妇秘书人妻系列| 好硬好湿好爽再深一点动态图片| 野花社区WWW在线视频官网| 欧美高清视频手机在在线| 成人网站WWW污污污网站| 午夜理论电影在线观看亚洲| 久久国产欧美成人网站| AV无码中文字幕不卡一区二区三| 少妇极品熟妇人妻200片| 好儿子妈妈今天就是你的女人 | でも私はあなたより賢いです意思 | 国产自偷自偷免费一区| 在公交上被灌满白浆的视频 | 久久久久 亚洲 无码 AV 专 | 亚洲精品国产AⅤ成拍色拍| 蜜臀色欲AV在线播放国产日韩| 处破痛哭A√18成年片免| 亚洲AV午夜成人片精品| 男女做AJ视频免费的网站| 高清中文字幕成人AV| 亚洲日韩久久综合中文字幕| 琪琪电影午夜理论片YY6080| 国产裸拍裸体视频在线观看 | 八戒八戒WWW资源网在线观看| 小蜜被两老头吸奶头| 老公朋友东西好大| 公交车挺进朋友人妻的身体里| 亚洲精品无码AⅤ片桃花岛| 欧美日韩国产精品自在自线| 国产日产欧美一区二区蜜桃| 中文字幕亚洲综合久久综合| 天天躁夜夜踩很很踩2022| 久久婷婷五月综合成人D啪| 丰满熟妇乱又伦在线无码视频| 亚洲欧洲成人AV电影网| 日本精产国品一二三产品区别| 精品国产AⅤ一区二区三区V免费|