V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Geo200
V2EX  ›  Vue.js

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

  •  
  •   Geo200 · 2018-08-22 09:17:19 +08:00 · 2613 次点击
    这是一个创建于 2316 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在移动端开发中,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

    4 条回复    2018-08-22 15:18:11 +08:00
    wu67
        1
    wu67  
       2018-08-22 09:59:24 +08:00
    战略 mark
    del1214
        2
    del1214  
       2018-08-22 10:16:30 +08:00 via iPhone
    支持
    SakuraKuma
        3
    SakuraKuma  
       2018-08-22 13:37:38 +08:00
    那两事件全局了.
    Geo200
        4
    Geo200  
    OP
       2018-08-22 15:18:11 +08:00 via iPhone
    @SakuraKuma 你指的是 touchstart 和 touchmove 这两事件吗?这是绑定在指定元素上的,如果组件销毁,touch 事件也会跟着 remove 掉
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1412 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 17:15 · PVG 01:15 · LAX 09:15 · JFK 12:15
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.