濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 移動(dòng)端解決懸浮層(懸浮header、footer)會(huì)遮擋住內(nèi)容的3種方法

移動(dòng)端解決懸浮層(懸浮header、footer)會(huì)遮擋住內(nèi)容的3種方法

熱門標(biāo)簽:申請(qǐng)400電話流程簡(jiǎn)介 pageadm實(shí)現(xiàn)地圖標(biāo)注 呼和浩特外呼電銷系統(tǒng)排名 外呼線穩(wěn)定線路 南通數(shù)據(jù)外呼系統(tǒng)推廣 阜陽(yáng)企業(yè)外呼系統(tǒng) 邢臺(tái)縣地圖標(biāo)注app 外呼系統(tǒng)電話怎么投訴 地圖標(biāo)注位置能賺錢嗎

在現(xiàn)在的前端頁(yè)面中,尤其是移動(dòng)端,經(jīng)常會(huì)需要將<header>或者是<footer>模塊懸浮出來(lái),跟隨頁(yè)面的滑動(dòng)保持定位在頁(yè)面的最上方或者是最下方,如下圖所示。

“回復(fù)主題”模塊,就是跟隨頁(yè)面的浮動(dòng)一直懸浮在頁(yè)面的最下方,代碼結(jié)構(gòu)如下。


復(fù)制代碼
代碼如下:

...
<section class='footer'>
<div class='reply-topic'>回復(fù)主題</div>
</section>
...

實(shí)現(xiàn)這樣的功能當(dāng)然是利用position:fixed。但是,使用position:fixed有一個(gè)bug,以懸浮<footer>在最下方為例(懸浮<header>同理),當(dāng)頁(yè)面滑到最下方的時(shí)候,由于是fixed定位,脫離了正常文檔流,導(dǎo)致會(huì)遮擋住一部分內(nèi)容。如下所示:

上面左邊是有問題的顯示,右邊為正常顯示。那么,如何解決這個(gè)問題呢?在此,我拋磚引玉提出三種我的看法,希望能有更好的方法。

法一. Javasrript解決

  使用js解決,判定當(dāng)滑動(dòng)條滑到頁(yè)面內(nèi)容的最底端的時(shí)候,將原本會(huì)脫離文檔流的fixed定位改為不脫離文檔流的relative定位即可。

  使用腳本解決問題是最繁重的方法,能用css解決的盡量不使用腳本,但是也是一種方法。

復(fù)制代碼
代碼如下:

//滾動(dòng)條在Y軸上的滾動(dòng)距離
function getScrollTop(){
  return document.body.scrollTop;
}
//文檔的總高度
function getScrollHeight(){</p> <p>   return document.body.clientHeight;
}
//瀏覽器視口的高度
function getWindowHeight(){
var windowHeight = 0;
     if(document.compatMode == "CSS1Compat")
    {
       windowHeight = document.documentElement.clientHeight;
    }
    else
   {
      windowHeight = document.body.clientHeight;
    }
    return windowHeight;
}</p> <p> //滑動(dòng)監(jiān)聽
  window.onscroll = function(){
//滑到底部時(shí)footer定于最下方,假定<footer>的height為60
if((getScrollHeight() - getScrollTop() - getWindowHeight()) > 61)
$('.footer').css('position','fixed');
else
$('.footer').css('position','relative');
}

 法二.給body加上padding-bottom

  給html<body>標(biāo)簽加上一個(gè)padding-bottom屬性,這樣正常文檔流的內(nèi)容距離body底部就會(huì)產(chǎn)生一個(gè)padding-bottom設(shè)置的距離。

  缺點(diǎn)是,考慮到現(xiàn)在項(xiàng)目上線之后模塊的復(fù)用及經(jīng)常需要合并css文件,當(dāng)其他頁(yè)面不需要這個(gè)懸浮塊,就會(huì)給不需要<footer>fixed定位的頁(yè)面造成負(fù)擔(dān),不推薦使用這種方法。

復(fù)制代碼
代碼如下:

//假定<footer>的高度為60px
body
{
padding-bottom: 60px;
}

法三.增加同級(jí)占位符<div>

  個(gè)人認(rèn)為這個(gè)方法最為實(shí)用,在<footer>塊之外再包裹一層div,然后再增加一個(gè)與<footer>同級(jí)的<div>塊,這個(gè)<div>塊的高度設(shè)置為與<footer>同樣高,不包含任何內(nèi)容,這樣就可以起到一個(gè)占位符的效果,在頁(yè)面最底占據(jù)與<footer>同樣高度的空間,當(dāng)然頁(yè)面滑到最下方,原本的<footer>懸動(dòng)塊就會(huì)與這個(gè)占位塊完美重疊。且不會(huì)對(duì)其他頁(yè)面產(chǎn)生影響。代碼如下:

  唯一缺點(diǎn)是不符合語(yǔ)義化,增加了無(wú)實(shí)質(zhì)內(nèi)容的空標(biāo)簽。

復(fù)制代碼
代碼如下:

<!-- footer外包裹一層div-->
<div>
<!--充當(dāng)占位符的div塊,無(wú)實(shí)質(zhì)內(nèi)容 -->
<div style="height:60px;"></div> </p> <p> <!--fixed懸浮出來(lái)的footer -->
<section class='footer'>
<div class='reply-topic'>回復(fù)主題</div>
</section>
</div>

 以上是我想到的三種方法,才疏學(xué)淺,文中若有紕漏錯(cuò)誤或者有更好的方法,萬(wàn)望告知,感謝。

標(biāo)簽:德州 內(nèi)蒙古 黃山 撫順 鶴崗 蚌埠 辛集 楊凌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《移動(dòng)端解決懸浮層(懸浮header、footer)會(huì)遮擋住內(nèi)容的3種方法》,本文關(guān)鍵詞  移動(dòng),端,解決,懸浮,層,header,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《移動(dòng)端解決懸浮層(懸浮header、footer)會(huì)遮擋住內(nèi)容的3種方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于移動(dòng)端解決懸浮層(懸浮header、footer)會(huì)遮擋住內(nèi)容的3種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    江安县| 金乡县| 丘北县| 偏关县| 顺昌县| 桓台县| 喀喇沁旗| 连江县| 油尖旺区| 九龙坡区| 连平县| 莱州市| 天柱县| 彩票| 嫩江县| 察雅县| 包头市| 巴南区| 防城港市| 阜平县| 杭锦旗| 安阳县| 南部县| 甘肃省| 中阳县| 二手房| 福鼎市| 新野县| 潜江市| 张家港市| 苍南县| 田阳县| 略阳县| 旺苍县| 静安区| 凤庆县| 石城县| 琼结县| 新民市| 新昌县| 谷城县|