在桌面浏览器上,我可以使用以下
javascript垂直修复元素,但仍允许水平滚动.如您所见,它会在每个滚动事件上重新定位元素.要了解我的意思,请尝试在此
JSFiddle中水平和垂直滚动.
var verticallyFixedBox = document.getElementById('verticallyFixedBox'); window.addEventListener('scroll',function() { verticallyFixedBox.style.top = '' + document.body.scrollTop + 'px'; });
然而,这种逻辑对于移动浏览器来说是失败的,因为移动浏览器显然不会在整个拖动完成之前进行绘制,从而导致不稳定的体验.
垂直修复元素的好方法是什么,但仍然允许移动浏览器的水平滚动?
解决方法
如果你使用一个设置为height的容器盒:100%并将html和body元素的高度设置为100%,那么你可以使用position:absolute;顶部:0;对于固定标题和设置溢出:自动(或滚动)您要垂直滚动的框.
请记住将您的正文和html边距设置为0以避免浏览器默认样式.
我已经更新了你的小提琴:http://jsfiddle.net/jb489ddL/1/
此解决方案根本不使用javascript,因此它可以在移动浏览器上运行,因为您不依赖于滚动事件.