真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在移動(dòng)Web頁面中使用CSS固定頁腳

本篇內(nèi)容介紹了“怎么在移動(dòng)Web頁面中使用CSS固定頁腳”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

在湖北等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需定制,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),營銷型網(wǎng)站,外貿(mào)網(wǎng)站建設(shè),湖北網(wǎng)站建設(shè)費(fèi)用合理。

一種單頁應(yīng)用的頁面結(jié)構(gòu)

面向移動(dòng)端的單頁應(yīng)用(Single Page Web Application),從頁面代碼上來說,會(huì)使用較一般網(wǎng)頁不同的結(jié)構(gòu)。單頁應(yīng)用并不是說應(yīng)用只需要一個(gè)視圖,而是說可以將組成應(yīng)用的多個(gè)視圖集合在一個(gè)網(wǎng)頁內(nèi)呈現(xiàn),且在視圖之間能夠自由切換(平滑的動(dòng)畫形式居多)。

我制作單頁應(yīng)用使用的是一種常見方法,像下面這樣:

CSS Code復(fù)制內(nèi)容到剪貼板

  1.   

  2.     

  

  •     

  •   

  •     

  •   

  •   

  •   

  • .view-page{   

  •     display: none;   

  •     position: absolute;   

  •     width: 100%;   

  •     height: 100%;   

  •     left: 0;   

  •     top: 0;   

  • }   

  • .view-current{   

  •     display: block;   

  • }  

  • 可以看出,其原理是視圖都由絕對定位的覆蓋屏幕大?。梢娨暱冢┑脑貥?gòu)成,在某一時(shí)間點(diǎn),只會(huì)顯示一個(gè)視圖。
    固定頁腳的問題

    那么,固定頁腳是一個(gè)什么問題呢?請看下圖:
    怎么在移動(dòng)Web頁面中使用CSS固定頁腳

    先說說什么是固定頁腳吧。上圖右可以看到,當(dāng)頁面內(nèi)容較多,超出一屏的高度時(shí),頁腳是“自然地”緊跟在內(nèi)容后邊,滾動(dòng)到底部時(shí),才會(huì)看到位于最下方的頁腳。同時(shí),上圖左可以看到,當(dāng)頁面內(nèi)容較少時(shí),頁腳則直接位于屏幕最下方,剩余區(qū)域則是空白。這就是固定頁腳,它可以算是一種比較理想的“總是在它應(yīng)該在的位置”的頁腳。

    那么,問題來了。參考上圖左,除了固定頁腳的效果之外,現(xiàn)在還要求當(dāng)頁面內(nèi)容較少時(shí),頁面內(nèi)容(Content)可以水平垂直居中于剩余的空間(Container)。在上述單頁應(yīng)用的頁面結(jié)構(gòu)中,應(yīng)該如何實(shí)現(xiàn)呢?
    方法探討
    水平垂直居中與Flexbox

    讓我們一步一步來。先完成“水平垂直居中”。由于內(nèi)容高度不確定,所以這里適合使用彈性盒模型(Flexbox)。

    關(guān)于彈性盒模型的指南,推薦閱讀A Complete Guide to Flexbox 和Dive into Flexbox 。

    應(yīng)用Flexbox實(shí)現(xiàn)水平垂直居中可以先得到這樣的代碼(由于其他視圖不再需要,這里只保留一個(gè)視圖):

    CSS Code復(fù)制內(nèi)容到剪貼板

    1.   

    2.        

    3.            

    4.                

    5.            

    6.        

    7.   

    上面的div.container對應(yīng)前面圖中的剩余空間(作為容器),div.content則是需要水平垂直居中的內(nèi)容。對應(yīng)的css是:

    CSS Code復(fù)制內(nèi)容到剪貼板

    1. .container{   

    2.     min-height: 100%;   

    3. }  

    flex-container、justify-content-center、align-items-center都是彈性盒模型的輔助class(熟悉了Flexbox就可以很快理解)。使用輔助class是因?yàn)閺椥院心P蛷那暗胶髱捉?jīng)變化,兼容處理需要稍多代碼。這些輔助class的css是:

    CSS Code復(fù)制內(nèi)容到剪貼板

    1. .flex-container{   

    2.     display: -webkit-box;   

    3.     display: -webkit-flexbox;   

    4.     display: -ms-flexbox;   

    5.     display: -webkit-flex;   

    6.     display: flex;   

    7. }   

    8.   

    9. .justify-content-center{   

    10.     -webkit-box-pack: center;   

    11.     -webkit-flex-pack: center;   

    12.     -ms-flex-pack: center;   

    13.     -webkit-justify-content: center;   

    14.     justify-content: center;   

    15. }   

    16.   

    17. .align-items-center{   

    18.     -webkit-box-align: center;   

    19.     -webkit-flex-align: center;   

    20.     -ms-flex-align: center;   

    21.     -webkit-align-items: center;   

    22.     align-items: center;   

    23. }  

    到此,水平垂直居中就完成了。
    實(shí)現(xiàn)固定頁腳

    現(xiàn)在加入頁腳的部分。這時(shí)候html代碼變成:

    CSS Code復(fù)制內(nèi)容到剪貼板

    1.   

    2.        

    3.            

    4.                

    5.            

    6.            

    7.        

    8.   

    注意,div.view-page是絕對定位,且定義了height: 100%;,而此時(shí)div.container也定義了min-height: 100%;??紤]到要“為頁腳留空間”,結(jié)合傳統(tǒng)網(wǎng)頁中的固定頁腳的做法,得到完整的css:

    CSS Code復(fù)制內(nèi)容到剪貼板

    1. .container{   

    2.     min-height: 100%;   

    3.     margin-bottom: -120px;   

    4.     padding-bottom: 120px;   

    5.     -webkit-box-sizing: border-box;   

    6.     box-sizing: border-box;   

    7. }   

    8. .footer{   

    9.     height: 120px;  /*假定頁腳的高度為120px*/  

    10. }  

    以上就是在這種條件下的固定頁腳的實(shí)現(xiàn)方法。雖然最后看起來只是這樣一小段代碼,但我還是思考了相當(dāng)一段時(shí)間加上試驗(yàn)才得到。其中padding-bottom和負(fù)值的margin-bottom的結(jié)合應(yīng)用很關(guān)鍵。此外,作為移動(dòng)端的網(wǎng)頁,要想到使用box-sizing這個(gè)配合百分比會(huì)非常有用的CSS3屬性。
    其他形式的嘗試?

    我也試過使用主軸為垂直方向的Flexbox來實(shí)現(xiàn),但可惜經(jīng)過測試,flex-direction: column;還沒有被現(xiàn)在的主流手機(jī)瀏覽器所支持。
    傳統(tǒng)網(wǎng)頁的固定頁腳

    關(guān)于傳統(tǒng)網(wǎng)頁的固定頁腳,有一個(gè)專門的站點(diǎn)HTML5 CSS Sticky Footer介紹了其實(shí)現(xiàn)方法和原理,你也可以閱讀我以前寫的簡單實(shí)現(xiàn)固定在頁面底部的頁腳。

    “怎么在移動(dòng)Web頁面中使用CSS固定頁腳”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!


    當(dāng)前標(biāo)題:怎么在移動(dòng)Web頁面中使用CSS固定頁腳
    網(wǎng)站地址:http://weahome.cn/article/pdhheh.html

    其他資訊

    在線咨詢

    微信咨詢

    電話咨詢

    028-86922220(工作日)

    18980820575(7×24)

    提交需求

    返回頂部