微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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,因此它可以在移动浏览器上运行,因为您不依赖于滚动事件.

原文地址:https://www.jb51.cc/js/159344.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐