• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

html - 防止iPhone上的垂直滚动

[复制链接]
菜鸟教程小白 发表于 2022-12-12 16:39:24 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我有一个移动网站,其中有一个包含三个 div 的主包装器 - 所有的高度都是固定的,总高度为 480 像素。里面的前两个 div 是非常短的标题,底部是主要内容所在的位置,并且有一个溢出-y 滚动。我将 html 和 body 设置为 overflow-y:hidden。我只希望主要内容 div 垂直滚动,完全没有其他内容,使标题始终完整可见。

当我在我的桌面浏览器中查看它时,它工作正常。在我的 iPhone 模拟器中,如果我在该内容 div 中单击并拖动它,它会正确滚动,但如果我从其中一个标题单击并拖动,或者我用两根手指在触控板上滑动,它会滚动整个页面,而不仅仅是内容。这会导致顶部标题滚出页面。我没有真正的 iphone 来测试,但我的客户告诉我,同样的事情发生在她的 iphone 上。

我尝试将主包装器的高度设置为非常短的值(300 像素),因此理论上无论溢出设置如何都不需要滚动页面,但它仍然会滚动。我也尝试访问this very short page甚至在模拟器中它也会滚动一点。我还尝试将标题设置为 position:fixed 但没有运气。

如何让页面停止滚动远离标题?



Best Answer-推荐答案


您可以将“touchmove”事件绑定(bind)到其他两个 div,并使用 prevent default。

<div id="main-wrapper">
    <div id="header"></div>
    <div id="content"></div>
    <div id="footer"></div>
</div>

使用jQuery和

jQuery(function($) {
   $("#header").on(‘touchmove’, function(e) { e.preventDefault() });
   $("#footer").on(‘touchmove’, function(e) { e.preventDefault() });
}

这将阻止浏览器执行其默认行为。

关于html - 防止iPhone上的垂直滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20136566/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap