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


Posted in Javascript onJune 08, 2017

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

<div class="overlayer" @touchmove.prevent >
  </div>

对,就是这么简单,加上@touchmove.prevent就可以屏蔽滑动页面了,然后再和普通的遮罩层一样,加点样式

/*遮罩层*/
.overlayer{
  position:fixed;
  left:0;
  top:0;
  width:100%;
  height:100%;
  z-index:10;
}

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

以下是废话和原理

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

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

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

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

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

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

 首先想到了mint ui中的popup组件;

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

注意!

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

<div class="overlayer" @touchmove.prevent >
  </div>
  <div class="popup">
    如果在这个div中滑动,触发的事件是不会经过overlayer的,也就无法屏蔽滑动了
  </div>

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

<!--plan A-->
  <div class="overlayer" @touchmove.prevent >
    <div class="popup">
      如果在这个div中滑动,触发的事件会经过overlayer,可以屏蔽滑动
    </div>
  </div>

  <!--plan B-->
  <div class="overlayer" @touchmove.prevent >
  </div>
  <div class="popup" @touchmove.prevent>
    如果在这个div中滑动,触发的事件也会被禁用默认行为, 也可以屏蔽滑动
  </div>

PC端方案

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

<div class="overlayer" @scroll.prevent >
  </div>

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

Javascript 相关文章推荐
jQuery+ajax实现动态执行脚本的方法
Jan 27 Javascript
jQuery遍历json中多个map的方法
Feb 12 Javascript
js控制页面的全屏展示和退出全屏显示的方法
Mar 10 Javascript
jQuery实现向下滑出的二级菜单效果实例
Aug 22 Javascript
AngularJS 面试题集锦
Sep 06 Javascript
JavaScript利用Date实现简单的倒计时实例
Jan 12 Javascript
Angularjs中ng-repeat的简单实例
Aug 25 Javascript
浅谈在Vue-cli里基于axios封装复用请求
Nov 06 Javascript
vue 添加vux的代码讲解
Nov 30 Javascript
详解vue-cli项目中的proxyTable跨域问题小结
Feb 09 Javascript
toString.call()通用的判断数据类型方法示例
Aug 28 Javascript
three.js显示中文字体与tween应用详析
Jan 04 Javascript
微信小程序开发之map地图实现教程
Jun 08 #Javascript
详解AngularJS用Interceptors来统一处理HTTP请求和响应
Jun 08 #Javascript
微信小程序开发之实现自定义Toast弹框
Jun 08 #Javascript
微信小程序开发之toast等弹框提示使用教程
Jun 08 #Javascript
javascript实现二叉树遍历的代码
Jun 08 #Javascript
微信小程序tabbar不显示解决办法
Jun 08 #Javascript
javascript实现二叉树的代码
Jun 08 #Javascript
You might like
2020显卡排行榜天梯图 显卡天梯图2020年3月最新版
2020/04/02 数码科技
php 使用GD库为页面增加水印示例代码
2014/03/24 PHP
PHP文件上传操作实例详解
2016/09/27 PHP
PHP基于curl post实现发送url及相关中文乱码问题解决方法
2017/11/25 PHP
js查错流程归纳
2012/05/04 Javascript
javascript事件绑定学习要点
2016/03/09 Javascript
JS基于构造函数实现的菜单滑动显隐效果【测试可用】
2016/06/21 Javascript
内容滑动切换效果jquery.hwSlide.js插件封装
2016/07/07 Javascript
基于Javascript实现文件实时加载进度的方法
2016/10/12 Javascript
JS+Canvas实现的俄罗斯方块游戏完整实例
2016/12/12 Javascript
微信小程序 实战程序简易新闻的制作
2017/01/09 Javascript
js仿搜狐视频记录片列表展示效果
2020/05/30 Javascript
深入理解vue Render函数
2017/07/19 Javascript
Vue组件选项props实例详解
2017/08/18 Javascript
vue学习笔记之v-if和v-show的区别
2017/09/20 Javascript
值得收藏的vuejs安装教程
2017/11/21 Javascript
JavaScript分步实现一个出生日期的正则表达式
2018/03/22 Javascript
jQuery实现B2B网站后台管理系统侧导航
2020/07/08 jQuery
Vue+penlayers实现多边形绘制及展示
2020/12/24 Vue.js
利用Python中unittest实现简单的单元测试实例详解
2017/01/09 Python
Python基于os.environ从windows获取环境变量
2020/06/09 Python
css3实现图片遮罩效果鼠标hover以后出现文字
2013/11/05 HTML / CSS
俄罗斯香水和化妆品在线商店:Aroma-butik
2020/02/28 全球购物
出口公司经理求职简历中的自我评价
2013/10/13 职场文书
竞聘医务工作人员的自我评价分享
2013/11/04 职场文书
个人实习生的自我评价
2014/02/16 职场文书
办公自动化专业大学生职业规划书
2014/03/06 职场文书
机械设计专业大学生职业生涯规划书范文
2014/09/13 职场文书
班子成员四风问题自我剖析材料
2014/09/29 职场文书
行政执法作风整顿剖析材料
2014/10/11 职场文书
出差报告怎么写
2014/11/06 职场文书
烟台的海导游词
2015/02/02 职场文书
python编写函数注意事项总结
2021/03/29 Python
JavaScript小技巧带你提升你的代码技能
2021/09/15 Javascript
Python装饰器详细介绍
2022/03/25 Python
我家女友可不止可爱呢 公开OP主题曲无字幕动画MV
2022/04/11 日漫