成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

移動端頁面頭部固定定位的絕對定位實現(xiàn)

terasum / 1914人閱讀

摘要:在移動端進行開發(fā)時,通常整個頁面的頭部會固定一個區(qū)域,比如下圖淘寶中的頭部。其中的默認定位都是。因此最終的代碼形式是禁用滾動條,實現(xiàn)相對于的絕對定位代替固定定位。因此如果有元素找不到非的祖先元素,那么是相對于進行定位的。

在移動端進行開發(fā)時,通常整個頁面的頭部會固定一個區(qū)域,比如下圖淘寶中的頭部。這個區(qū)域無論怎么劃屏都是可見的。在PC端,我們可以使用position:fixed來實現(xiàn)。但是由于position:fixed存在一定的兼容性問題,而且移動端的視口較多,這個固定究竟是相對于哪個視口,很容易搞錯。因此,通常都會使用絕對定位來代替固定定位。下面具體代碼舉例:

HTML代碼如下所示:


        

CSS代碼如下所示:

            .header-box{
                /*position:fixed;*/
                position:absolute;
                left:0;
                top:0;
                width:100%;
                height:179px;
                background:#ef3229;
            }
            
        
            ul>li{
                height:350px;
                border-bottom: 1px solid black;
            }

上面的html中定義了頂部固定區(qū)域和下方內(nèi)容區(qū)域。頂部使用了position進行了絕對定位,設(shè)置了left為0,top為0。內(nèi)容區(qū)域高度超過了可視區(qū)。
最終得到的效果如下圖所示:

這時候,會發(fā)現(xiàn)出現(xiàn)了滾動。滑動之后本來應(yīng)該固定在頂部的區(qū)域又不見了。也就是說我們并沒有實現(xiàn)我們想要的使用絕對定位代替固定定位。這是為什么了?這里,我們需要理解兩個重要知識點:

這里的絕對定位到底是相對于誰進行定位的?

這里的滾動條到底是加在誰身上?

首先分析第一個問題:我們知道position:absolute是相對于距離最近的position值不為static的定位祖先元素進行定位的,如果沒有定位的祖先元素,那么就是相對于根節(jié)點document進行定位的。那么,我們的header元素的祖先元素有body,html,document。 其中body,html的默認定位都是static。也就是說,這里最終是相對于document進行定位的。

再分析第二個問題:內(nèi)容超出瀏覽器高度時,滾動條到底是加在誰身上。事實上這里應(yīng)該是加在html元素身上的。
理解了上面兩個知識點,那么我們就可以進行分析了。我們知道正是由于html元素身上出現(xiàn)滾動條,正是由于滾動條的滾動才會導(dǎo)致document超出瀏覽器窗口。因此我們需要首先需要做的是將html的滾動條進行禁用。

html{
  overflow:hidden;
}

雖然禁用了html的滾動條解決了使用絕對定位代替固定定位的問題,但是帶來了新的問題。那就是整個頁面都不再具有滾動條了。但是事實上我們是需要滾動條的,因此我們可以在body身上添加滾動條。

html{
    height:100%;
}
body{
    height:100%;
    overflow:auto;
}

由于需要將body的高度設(shè)置為瀏覽器的高度,而html的高度取決于瀏覽器高度,因此先設(shè)置html高度為瀏覽器高度,然后body繼承自html即可。

因此最終的代碼形式是:

            html{
                height:100%;
                overflow:hidden;  //禁用滾動條,實現(xiàn)相對于document的絕對定位代替固定定位。
            }
            body{
                
                height:100%;
                overflow:auto;   //添加滾動條
            }
            ul{
                margin-top:179px;
                list-style: none;
            }
            .header-box{
                /*position:fixed;*/
                position:absolute;
                left:0;
                top:0;
                width:100%;
                height:179px;
                background:#ef3229;
            }
            
        
            ul>li{
                height:350px;
                border-bottom: 1px solid black;
            }

總結(jié):一些用到的相關(guān)知識:

html元素和body的元素的絕對定位默認值都是static。因此如果有元素找不到非static的祖先元素,那么是相對于document進行定位的。

html元素和body元素都是塊級元素。默認獨占一行,其寬度等于瀏覽器寬度。高度等于內(nèi)容區(qū)域的高度,如果給高度設(shè)置了height:100%。那么它的高度是瀏覽器高度。

html元素默認設(shè)置了overflow:auto。在內(nèi)容超出瀏覽器高度的時候就會出現(xiàn)滾動條。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/117248.html

相關(guān)文章

  • 移動頁面頭部固定定位絕對定位實現(xiàn)

    摘要:在移動端進行開發(fā)時,通常整個頁面的頭部會固定一個區(qū)域,比如下圖淘寶中的頭部。其中的默認定位都是。因此最終的代碼形式是禁用滾動條,實現(xiàn)相對于的絕對定位代替固定定位。因此如果有元素找不到非的祖先元素,那么是相對于進行定位的。 在移動端進行開發(fā)時,通常整個頁面的頭部會固定一個區(qū)域,比如下圖淘寶中的頭部。這個區(qū)域無論怎么劃屏都是可見的。在PC端,我們可以使用position:fixed來實現(xiàn)。...

    adie 評論0 收藏0
  • CSS入門指南-3:定位元素

    摘要:靜態(tài)定位下,每個元素在處在常規(guī)文檔流中,它們都是塊級元素,所以會在頁面中自上而下地堆疊。這說明絕對定位的元素脫離了常規(guī)文檔流,它現(xiàn)在是相對于頂級元素在定位。事實上,一個相對定位元素同時設(shè)置了和位移屬性值,實際上優(yōu)先級高于。 這是《CSS設(shè)計指南》的讀書筆記,用于加深學(xué)習(xí)效果。前一篇CSS入門指南-2:盒子模型、浮動和清除介紹了css盒子模型、浮動和清除,這一篇介紹 css元素的定位。 ...

    paulquei 評論0 收藏0
  • CSS入門指南-3:定位元素

    摘要:靜態(tài)定位下,每個元素在處在常規(guī)文檔流中,它們都是塊級元素,所以會在頁面中自上而下地堆疊。這說明絕對定位的元素脫離了常規(guī)文檔流,它現(xiàn)在是相對于頂級元素在定位。事實上,一個相對定位元素同時設(shè)置了和位移屬性值,實際上優(yōu)先級高于。 這是《CSS設(shè)計指南》的讀書筆記,用于加深學(xué)習(xí)效果。前一篇CSS入門指南-2:盒子模型、浮動和清除介紹了css盒子模型、浮動和清除,這一篇介紹 css元素的定位。 ...

    DesGemini 評論0 收藏0
  • 必懂之Sticky Footer(粘性頁腳)

    摘要:寫在最前是的一種布局場景。頁腳永遠固定在頁面的底部,頁面內(nèi)容不夠長的時候頁腳黏在視窗底部,內(nèi)容足夠長時會被向下移動。老式門戶網(wǎng)站由于內(nèi)容過短常常版權(quán)頁腳前移,移動端特定布局也需要來解決這些問題。 showImg(https://segmentfault.com/img/bVbrIV9?w=200&h=354); 寫在最前:Sticky Footer是css的一種布局場景。頁腳foot...

    piapia 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<