vue实现一个移动端屏蔽滑动的遮罩层
2017-12-01 18:12
477 查看
vue实现一个移动端屏蔽滑动的遮罩层
在扯废话浪费大家的时间之前,先上个代码好了,使用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>
相关文章推荐
- vue实现一个移动端屏蔽滑动的遮罩层实例
- jQuery操作dom实现弹出页面遮罩层(web端和移动端阻止遮罩层的滑动)
- 原生JS实现移动端模块的左右滑动切换效果,基于vue、stylus
- 【C#】对异步请求处理程序IHttpAsyncHandler的理解和分享一个易用性封装 【手记】走近科学之为什么明明实现了IEnumerable<T>的类型却不能调用LINQ扩展方法 【手记】手机网页弹出层后屏蔽底层的滑动响应 【手记】ASP.NET提示“未能创建类型”处理 【Web】一个非常简单的移动web消息框 【手记】解决EXCEL跑SQL遇“查询无法运行或数据库表无法打开...”
- vue 移动端今天写了一个根据后台传过来的http状态码,来实现跳转error页面
- 写一个移动端惯性滑动&回弹Vue导航栏组件 ly-tab
- 如何实现一个简单的Vue移动端组件库
- android中实现一个DrawerLayout滑动菜单
- 利用vue组件自定义v-model实现一个Tab组件方法示例
- 如何实现移动端弹出层弹出的时候页面不能滑动,关闭弹出层时页面恢复滑动
- 滑动条实现一个开关功能
- 【业务】Vue项目里利用md5的来实现一个权限系统的思路记录
- 实现一个可以左右滑动切换预览图带标题的相册
- vue实现移动端九宫格布局
- android滑动一个路线后 人物图片按此路线移动的实现
- 将一个view 的背景设为透明 但view上的图标 不透明 实现类似iphone ipad 主页的滑动效果
- 自己动手实现一个可垂直滑动的ViewGroup,相当于可以垂直滑动的viewpager
- vue中实现移动端的scroll滚动方法
- 用html5页面引入了一个jquery插件,实现平板上的向上滑动加载更多的功能
- 一个可往上加载和滑动到底部的的vue模板组件