javascript – 如何在移动浏览器中垂直修复元素但仍允许水平滚动?

前端之家收集整理的这篇文章主要介绍了javascript – 如何在移动浏览器中垂直修复元素但仍允许水平滚动?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在桌面浏览器上,我可以使用以下 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,因此它可以在移动浏览器上运行,因为您不依赖于滚动事件.

猜你在找的JavaScript相关文章