詳解iOS中position:fixed吸底時的滑動出現抖動的解決方案

這篇文章主要介紹了詳解iOS中position:fixed吸底時的滑動出現抖動的解決方案,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

兩種抖動

爲什麼抖動還會有兩種?

其實是我碰到過兩種抖動的場景,第一個場景是native的抖動,第二個場景是h5的抖動。

native的抖動

前端開發人員會在app中打開webview,這個時候iOS中position:fixed吸底時的滑動出現抖動應該是native造成的抖動,整個viewport跟着動,所以可以在生成schema的時候將參數bounce_disable(可能不一定都有這個參數,就看有沒有類似的參數進行控制)設置爲1禁止native的彈性效果,然後加上h5的這個效果,-webkit-overflow-scrolling 屬性可以幫我們實現這個效果,它控制元素在移動設備上是否使用滾動回彈效果。

h5的抖動

方案一

//我是吸頂頭部
.header{
 width:100%;
 height:50px;
 position:fixed;
 top:0px;
}
//我是中間要滑動的部分
.main{
 width:100%;
 height:auto;
 position:absolute;
 padding-top:50px;
 padding-bottom:50px;
 box-sizing:border-box;
 overflow-y:scroll;
}
//我是吸底尾部
.footer{
 width:100%;
 height:50px;
 position:fixed;
 bottom:0px;
}

解釋:滑動部分overflow-y:scroll;所以在上下方向超出一屏的部分會變成滾動模式並且不溢出,然後這邊吸頂和吸底設置的高度都是50,所以對應的中間滑動部分分別有padding-top:50px;和padding-bottom:50px;設置box-sizing:border-box;所以padding的增加不會增加.main的高度。

方案二

transform: translateZ(0);
-webkit-transform: translateZ(0);

解釋:在使用position:fixed的元素上加上該屬性。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持神馬文庫。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章