CSS實現Sticky Footer

CSS 恒星网络 恆星網絡 2017-11-22

所謂 “Sticky Footer”,並不是什麼新的前端概念和技術,它指的就是一種網頁效果:

如果頁面內容不足夠長時,頁腳固定在瀏覽器窗口的底部;如果內容足夠長時,頁腳固定在頁面的最底部。但如果網頁內容不夠長,置底的頁腳就會保持在瀏覽器窗口底部。

所謂 “Sticky Footer”,並不是什麼新的前端概念和技術,它指的就是一種網頁效果:

如果頁面內容不足夠長時,頁腳固定在瀏覽器窗口的底部;如果內容足夠長時,頁腳固定在頁面的最底部。但如果網頁內容不夠長,置底的頁腳就會保持在瀏覽器窗口底部。

CSS實現Sticky Footer

實現方法

將內容部分的底部外邊距設為負數

這是個比較主流的用法,把內容部分最小高度設為100%,再利用內容部分的負底部外邊距值來達到當高度不滿時,頁腳保持在窗口底部,當高度超出則隨之推出的效果。

所謂 “Sticky Footer”,並不是什麼新的前端概念和技術,它指的就是一種網頁效果:

如果頁面內容不足夠長時,頁腳固定在瀏覽器窗口的底部;如果內容足夠長時,頁腳固定在頁面的最底部。但如果網頁內容不夠長,置底的頁腳就會保持在瀏覽器窗口底部。

CSS實現Sticky Footer

實現方法

將內容部分的底部外邊距設為負數

這是個比較主流的用法,把內容部分最小高度設為100%,再利用內容部分的負底部外邊距值來達到當高度不滿時,頁腳保持在窗口底部,當高度超出則隨之推出的效果。

CSS實現Sticky Footer​這個方法需要容器裡有額外的佔位元素(如.push)

需要注意的是.wrapper的margin-bottom值需要和.footer的負的height值保持一致,這一點不太友好。

2. 將頁腳的頂部外邊距設為負數

既然能在容器上使用負的margin bottom,那能否使用負margin top嗎?當然可以。給內容外增加父元素,並讓內容部分的底部內邊距與頁腳高度的值相等。

所謂 “Sticky Footer”,並不是什麼新的前端概念和技術,它指的就是一種網頁效果:

如果頁面內容不足夠長時,頁腳固定在瀏覽器窗口的底部;如果內容足夠長時,頁腳固定在頁面的最底部。但如果網頁內容不夠長,置底的頁腳就會保持在瀏覽器窗口底部。

CSS實現Sticky Footer

實現方法

將內容部分的底部外邊距設為負數

這是個比較主流的用法,把內容部分最小高度設為100%,再利用內容部分的負底部外邊距值來達到當高度不滿時,頁腳保持在窗口底部,當高度超出則隨之推出的效果。

CSS實現Sticky Footer​這個方法需要容器裡有額外的佔位元素(如.push)

需要注意的是.wrapper的margin-bottom值需要和.footer的負的height值保持一致,這一點不太友好。

2. 將頁腳的頂部外邊距設為負數

既然能在容器上使用負的margin bottom,那能否使用負margin top嗎?當然可以。給內容外增加父元素,並讓內容部分的底部內邊距與頁腳高度的值相等。

CSS實現Sticky Footer

3. 使用flexbox彈性盒佈局

以上方法的footer高度都是固定的,通常來說這不利於網頁佈局:內容會改變,它們都是彈性的,一旦內容超出固定高度就會破壞佈局。所以給footer使用flexbox吧,讓它的高度可以變大變小變漂亮~

所謂 “Sticky Footer”,並不是什麼新的前端概念和技術,它指的就是一種網頁效果:

如果頁面內容不足夠長時,頁腳固定在瀏覽器窗口的底部;如果內容足夠長時,頁腳固定在頁面的最底部。但如果網頁內容不夠長,置底的頁腳就會保持在瀏覽器窗口底部。

CSS實現Sticky Footer

實現方法

將內容部分的底部外邊距設為負數

這是個比較主流的用法,把內容部分最小高度設為100%,再利用內容部分的負底部外邊距值來達到當高度不滿時,頁腳保持在窗口底部,當高度超出則隨之推出的效果。

CSS實現Sticky Footer​這個方法需要容器裡有額外的佔位元素(如.push)

需要注意的是.wrapper的margin-bottom值需要和.footer的負的height值保持一致,這一點不太友好。

2. 將頁腳的頂部外邊距設為負數

既然能在容器上使用負的margin bottom,那能否使用負margin top嗎?當然可以。給內容外增加父元素,並讓內容部分的底部內邊距與頁腳高度的值相等。

CSS實現Sticky Footer

3. 使用flexbox彈性盒佈局

以上方法的footer高度都是固定的,通常來說這不利於網頁佈局:內容會改變,它們都是彈性的,一旦內容超出固定高度就會破壞佈局。所以給footer使用flexbox吧,讓它的高度可以變大變小變漂亮~

CSS實現Sticky Footer

你還可以在上面添加header或在下面添加更多元素。可從以下技巧選擇其一:

flex: 1 使內容(如:.content)高度可以自由伸縮

margin-top: auto

相關推薦

推薦中...