vue-frozen:解决移动端 fixed 定位滚动击穿的 vue 指令

2018-08-22 09:17:19 +08:00
 Geo200

在移动端开发中,fixed 布局的遮罩层滚动过程中如果滚到顶部或底部,再继续进行滚动操作会把滚动事件传递到下一层,这种问题 pc 端直接使用 overflow:hidden 就可以解决,但这个方法在移动端无法使用,移动端完美解决这个问题的方案是实时读取 touchMove 事件,在滚到顶部或底部的时候禁止事件冒泡,这里我封装了 vue-frozen,在使用过程中直接在需要禁止滚动击穿的元素上加v-frozen指令即可,有多个禁止元素可以多次使用 v-frozen。

仓库地址: https://github.com/Geocld/vue-frozen

在线 demo: http://geocld.github.io/demo/v-frozen/index.html

2506 次点击
所在节点    Vue.js
4 条回复
wu67
2018-08-22 09:59:24 +08:00
战略 mark
del1214
2018-08-22 10:16:30 +08:00
支持
SakuraKuma
2018-08-22 13:37:38 +08:00
那两事件全局了.
Geo200
2018-08-22 15:18:11 +08:00
@SakuraKuma 你指的是 touchstart 和 touchmove 这两事件吗?这是绑定在指定元素上的,如果组件销毁,touch 事件也会跟着 remove 掉

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/482056

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX