touch事件移动端页面里面嵌套iframe

发布于 2022-09-01 12:06:15 字数 510 浏览 9 评论 0

移动端的html页面是多屏的,通过touch事件来翻页,现在页面中嵌套一个iframe页面,当当前屏幕是iframe的时候,滑动页面是不能翻页的,应该是iframe里面的页面把touchu事件监听到了,不会传递给父页面了,请问这个有什么办法可以解决吗?

测试页面:http://demo.nuonuo.me/

我使用的是iSlider.js来做的屏幕切换,demo中是上下滑动,第二屏中嵌入了一个iframe,如下图所示:

clipboard.png

当我在百度这个页面移动的时候,整个屏幕是不会切屏的,只会移动内部的页面,请问大家有什么解决办法吗,我测试过即使iframe里面的页面是不能滑动的时候,滑动iframe的时候,屏幕也不会切屏移动

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

断念 2022-09-08 12:06:15

根据题猪提供的测试案例调试了下, 发现 iSlider 无法捕获到iframe中的 touchmove事件。
如果要解决上述问题确实比较蛋疼,得在 iframe中监听 touchmove事件,然后在合适的时机(页面滑到底部/顶部)告诉父级页面,执行翻页操作(这种方法太 ugly 啦~)。

如果你可以保证你的的 iframe不会出现滚动条,或者即使出现也不让用户滚动的话,那么你可以给iframe一个属性值pointer-events: none;,这是最简单的解决问题的方式(不完美~)。

另外,我决定比较好的方案是采用 ajax 请求的方式来获取 iframe 中的内容,然后填充到一个容器中,这样就不存在上述问题了。

許願樹丅啲祈禱 2022-09-08 12:06:15

使用h5的postMessage即可完成iframe与页面的通信

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文