vue实现一个移动端屏蔽滑动的遮罩层实例

  

在扯废话浪费大家的时间之前,先上个代码好了,使用vue实现起来很简单……

        & lt; div类=@touchmove覆盖物。防止在;   & lt;/div>      

对,就是这么简单,加上<代码> @touchmove.prevent>      /*遮罩层*/.overlayer {   位置:固定;   左:0;   上图:0;   宽度:100%;   高度:100%;   z - index: 10;   }      

如此,便可以了_(:з)∠)_,vue真是好用啊……

  

<强>以下是废话和原理

  

开发移动端页面的时候有一个很比较常见的需求,在出现弹窗时,禁止滑动弹窗后面的主体页面;,

  

实际上大部分弹窗插件(或者组件)都带了这样的功能,所以我自己也从来没研究过这个;
  

  

,这次的项目突然出现了一个需要自己写弹窗的场景……我瞬间就懵逼了QwQ
  

  

虽然毫无思路,但是代码还是要写的,效果还是要实现的,问题还是要解决的,而程序员解决问题的第一步,自然就是先去百度一下。
  

  

,一般来讲吧,普通问题都可以直接百度解决,百度不到的再考虑问人,屏蔽滑动的遮罩层这样常见的需求,自然是有一大堆的解决方案,不过……太多了根本没法选啊(╯‵□′)╯︵┻━┻
  

  

随便试了一套方案,未果,遂放弃了继续尝试的打算……还是去翻别人的源码吧。
  

  

,首先想到ui中了薄荷的弹出组件;
  

  

认真阅读了一下,发现这个遮罩层也没做什么事情,就是屏蔽了一下touchmove事件,拿到这个思路再回去自己查了下资料,移动端的屏幕滑动,实际上就是touchmove事件的默认行为,在冒泡过程中任何一层阻止这个默认行为,都可以阻止屏幕滑动,弄懂原理,实现起来就简单了,传统做法是在身体上添加一个touchmove事件处理器,在显示遮罩层的时候使用<代码> .preventDefault() 方法阻止默认行为,而vue就更简单了,把弹窗之类的都写在遮罩层元素内部,然后直接在遮罩层上加上一个取消默认行为的事件处理器,就可以咯~

  

<强>注意!

  

如果弹窗不在遮罩层内部,那么冒泡就不会经过遮罩层,也就无法屏蔽滑动了

0.0         & lt; div类=@touchmove覆盖物。防止在;   & lt;/div>   & lt; div类=暗觥北?   如果在这个div中滑动,触发的事件是不会经过覆盖物的,也就无法屏蔽滑动了   & lt;/div>      

如果实在不能把弹窗放到遮罩层内,那么给弹窗加一个单独的.prevent修饰符也可以,下面这两种方式都是有效的:

        & lt; !——计划——比;   & lt; div类=@touchmove覆盖物。防止在;   & lt; div类=暗觥北?   如果在这个div中滑动,触发的事件会经过覆盖物,可以屏蔽滑动   & lt;/div>   & lt;/div>      & lt; !——B计划——比;   & lt; div类=@touchmove覆盖物。防止在;   & lt;/div>   & lt; div类=暗觥盄touchmove.prevent>   如果在这个div中滑动,触发的事件也会被禁用默认行为,也可以屏蔽滑动   & lt;/div>   之前      

<强> PC端方案

  

这种屏蔽方式只是屏蔽了滑动,对于PC端的鼠标滚轮是无效的,但屏蔽鼠标滚轮也很简单,把touchmove事件处理器改成滚动事件的处理器就好了~就像这样:

        & lt; div类=@scroll覆盖物。防止在;   & lt;/div>      

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

vue实现一个移动端屏蔽滑动的遮罩层实例