sticky footers解决的问题是,当页面的内容不够长的时候,页脚块粘贴在视窗底部,如果内容足够长的话,页脚块会被内容向下推送。
我现在介绍的是相对复杂,但是兼容性最好的方案
首先看布局
data:image/s3,"s3://crabby-images/741cf/741cf4befcb6d753abdce537800f2d72f12046e6" alt="img_45ef0cde155bf57aa814392dbf529103.png"
重点说一下css
detail是最外层的包裹元素,需要给元素固定定位,height、width都是100%;并且让多出来的元素可以滚动查看,所以添加overflow:auto属性,弹层一般都是有颜色的,所以添加背景颜色为rgba(7,17,27,0.5)
detail-wrapper跟detail-close是同一级元素,.detail-close不多说是关闭按钮的盒子为了在屏幕内容不满一屏的时候显示在最下边,需要给元素添加负margin-top;detail-wrapper是内容的盒子设置最小的高度是屏幕的高度即min-height:100%;
重点是detail-main的样式添加,padding-bottom,这个属性是必须的,为了让关闭按钮不遮挡内容;
具体css样式如下
data:image/s3,"s3://crabby-images/4c6f5/4c6f5aaf84984158363706188b0f66864b9b1887" alt="img_b155e584c396079d8f690cc6e6b48f96.png"
当内容未满一屏幕的时候的最终效果如下
data:image/s3,"s3://crabby-images/75654/75654d54944f7f3b6330e3d9ba8dd1a7b4fc13d3" alt="img_f29968241605b6ee977a664f19fba4e4.png"
当内容超过一屏幕之后的效果
data:image/s3,"s3://crabby-images/2d148/2d148cb277956c3e1264303b88f1d702e6349655" alt="img_40a7cb63703783d7968648f7758f6210.png"
最后给大家推荐一个网站来更深一层的学习sticky footers布局https://www.w3cplus.com/css3/css-secrets/sticky-footers.html
补充:利用flex布局也可以实现同样的效果,代码如下
data:image/s3,"s3://crabby-images/46c2f/46c2f60fc0da2b5c94f1b57a97fc21b14f82a44e" alt="img_e63ea66ee0acbbd25513887944d6d752.png"
感兴趣的话可以查看我的另一篇文章,flex实战