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

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...