使用Vue-scroller,页面input框不能触发滑动的问题

因为项目中有个填写信息的页面,有很多input框,引入vue-scroller后发现在input区域滑动失效;看了一下引入的vue-scroller组件里的源码,发现在组件源码里的Scroller.vue中在touchStart、touchMove和mouseDownd方法的时候被return了

	touchStart(e) {
      // Don't react if initial down happens on a form element
      //注释掉这段代码就行
      // if (e.target.tagName.match(/input|textarea|select/i)) {
      //   return
      // }
      //注释掉这段代码就行
      if (e.target.tagName.match(/textarea|select/i)) {
        return;
      }
      this.scroller.doTouchStart(e.touches, e.timeStamp);
    },
     touchMove(e) {
     //touchMove也要重新加个判断,否则input框不能左右滑动
      if (!e.target.tagName.match(/input/i)) {
        e.preventDefault();
      }
      this.scroller.doTouchMove(e.touches, e.timeStamp);
    },

    mouseDown(e) {
      // Don't react if initial down happens on a form element
      //注释掉这段代码就行
      // if (e.target.tagName.match(/input|textarea|select/i)) {
      //   return
      // }
      //注释掉这段代码就行
      if (e.target.tagName.match(/textarea|select/i)) {
        return;
      }
      this.scroller.doTouchStart(
        [
          {
            pageX: e.pageX,
            pageY: e.pageY
          }
        ],
        e.timeStamp
      );
      this.mousedown = true;
    },

具体我也不知道阻止滑动input框区域是为了防止什么Bug,有知道的可以在评论区说一下;最后因为vue-scroller是npm引入的方式,怕会被更新掉,所以直接把组件代码copy出来放在项目的components目录下引用了
在这里插入图片描述
main.js引入方式和插件类似,使用方式和官方一样
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值