方法一:使用fixed
.box{
.roll{
padding-bottom:1rem;
}
footer{
position:fixed;bottom:0;z-index:999;
}
}
滾動(dòng)區(qū)域留下底部導(dǎo)航高度的padding距離
底部導(dǎo)航fixed固定定位到底部
設(shè)置z-index:999因?yàn)榈撞慷ㄎ粸閒ixed或absolute的時(shí)候,出現(xiàn)優(yōu)先級(jí)別較低,導(dǎo)致被其他div覆蓋的情況,那么這里就需要用到z-index,來(lái)讓他成為最高級(jí)別,不至于被覆蓋。
Fixed總是以body為定位時(shí)的對(duì)象,總是根據(jù)瀏覽器的窗口來(lái)進(jìn)行元素的定位.通過(guò)left top right bottom 屬性進(jìn)行定位.
當(dāng)我們需要使一個(gè)層相對(duì)于瀏覽器來(lái)自動(dòng)調(diào)整該層的位置的時(shí)候如果使用position:absolute來(lái)定位該層會(huì)發(fā)現(xiàn)不能達(dá)到想要的css效果.這時(shí)候就需要用到fixed屬性來(lái)定位該層了.
底部定位為fixed或absolute,存在輸入框的時(shí)候,會(huì)出現(xiàn)如下情況:
ios:激活輸入框時(shí),底部不會(huì)彈出來(lái)(合理)。
Android:激活輸入框時(shí),底部會(huì)跟著輸入框彈出來(lái)(不合理)
傳統(tǒng)解決辦法:通常將底部設(shè)置為fixed,當(dāng)激活輸入框的時(shí)候,將底部定位改為relative,即可兼容ios和Android。
方法二:使用absolute
.box{
position: relative;height: 100%;
.roll{
position: absolute;bottom:1rem;top: 0;overflow-y: scroll;-webkit-overflow-scrolling: touch;height: auto;
}
footer{
position: absolute;bottom:0;
}
}
讓box相對(duì)定位 滾動(dòng)區(qū)域和底部導(dǎo)航相對(duì)于盒子絕對(duì)定位.
overflow-y:scroll 裁剪內(nèi)容提供滾動(dòng)機(jī)制
設(shè)置-webkit-overflow-scrolling 屬性。這樣才能保證滾動(dòng)區(qū)域的流暢性,-webkit-overflow-scrolling控制元素在移動(dòng)設(shè)備上是否使用滾動(dòng)回彈效果。底部導(dǎo)航定位在底部.
over-flow-y 屬性規(guī)定如果溢出元素內(nèi)容區(qū)域的話是否對(duì)內(nèi)容的上下邊緣進(jìn)行裁剪
hidden 裁剪內(nèi)容不提供滾動(dòng)機(jī)制
scroll 裁剪內(nèi)容提供滾動(dòng)機(jī)制
auto 如果溢出框則應(yīng)該提供滾動(dòng)機(jī)制
-webkit-overflow-scrolling屬性控制元素在移動(dòng)設(shè)備上是否使用滾動(dòng)回彈效果
auto 使用普通滾動(dòng)當(dāng)手指從觸摸屏上移開(kāi)滾動(dòng)會(huì)立即停止
touch 使用具有回彈效果的滾動(dòng)當(dāng)手指從觸摸屏上移開(kāi),內(nèi)容會(huì)繼續(xù)保持一段時(shí)間的滾動(dòng).
注意:在部分瀏覽器中設(shè)置overflow-y: scroll;會(huì)出現(xiàn)滾動(dòng)條,這時(shí)候我們需要全局定義如下樣式:
::-webkit-scrollbar{//scroll滾動(dòng)條設(shè)置
width: 0px; height: 0px;background-color: #fff;
}
方法三:使用flex
.box{
display:flex;display: -webkit-flex;height:100%;flex-direction:column;
.roll{
flex: 1; width: 100%;overflow-y: scroll;-webkit-overflow-scrolling: touch;height: auto;
}
}
display:flex彈性布局
flex:1
flex
子元素之間等比例空間分配
子元素所占剩余空間分配
flex屬性是以下三個(gè)屬性的簡(jiǎn)寫(xiě)
flex-grow:0 定義彈性盒子的拉伸因子即子項(xiàng)分配父項(xiàng)剩余空間的比默認(rèn)值為0
flex-shrink:1指定flex元素的收縮規(guī)則 子項(xiàng)的收縮所占的份數(shù)默認(rèn)值為1
flex-basis:auto 指定了flex元素在主軸方向上的初始大小即子項(xiàng)的寬度.
flex-direction 規(guī)定靈活項(xiàng)目的方向
row靈活的項(xiàng)目將水平顯示
row-reverse
column靈活的項(xiàng)目將垂直顯示
column-reverse