首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

javascript对点击事件拖动事件的区分

由于是悬浮的,那么就会考虑用户会出现哪几种可能的操作,一个是直接点击,另外一种就是在屏幕上先拖动几下,然后再点击。 那么为了完美的实现这个需求,那么该怎么办呢?...最重要的就是要区分点击事件拖动事件。 我们都知道,点击事件是被点击的对象可看做是静止不动的,而拖动事件的对象很明显是移动的。...那么思路就应该是先判断事件对象是否有移动的现象, 但是由于不管是在点击事件拖动事件,其都有一个鼠标按下的一个过程和一个松开的过程,只不过拖动事件多了一个拖动动作。...= null;   //先设置一个定时器处理; var isDrag = false;             //声明拖动的默认状态是:否 //创建目标被点击(鼠标按下)的函数 function entranceDivDown...自己整理了一份2018最全面前端学习资料,从最基础的HTML+CSS+JS到移动端HTML5到各种框架都有整理,送给每一位前端小伙伴,这里是小白聚集地,欢迎初学和进阶中的小伙伴!

4.9K30
您找到你想要的搜索结果了吗?
是的
没有找到

移动端touch拖动事件和click事件冲突问题解决

实现效果 类似微信里的悬浮窗效果,苹果手机的悬浮球功能效果 可以点击拖动,然后吸附在窗口边缘 点击悬浮球,可以跳转界面,或者更改悬浮球的形态 准备 移动端使用 touch事件类型: touchstart...问题 当给元素添加了touch事件之后,click事件就不会出发了,那么怎么模拟点击效果呢?...有可能拖动了一圈又回到初始位置 结合计算触摸时长和触摸元素起始位置两种方式,逻辑比较复杂 下面看我是怎么做的: 首先应该了解触摸行为的事件响应机制: 如果有拖动行为,事件执行次序为:touchstart...-> touchmove-> touchend 没有拖动行为,事件执行次序为:touchstart-> touchend 从上面的分析来看,我们可以从touchmove 入手,继续往下看 解决...,属于点击行为 在touchend事件最后,重置isMoved为初始值false,这样每一个触摸操作都可以进入同样的逻辑,不用担心状态混乱 完美解决模拟点击行为 ---- 我是 甜点cc 热爱前端

2.1K20

Touch事件实现View拖动

Touch监听事件可以监听手指在屏幕上的行为,例如按下、滑动。抬起。根据这些事件,可以做出View任意推动的效果。...注意: onTouch和onClick事件冲突问题:   当同时实现了Touch和Click事件时,会发生冲突,如何避免?在我们的onTouchListener的监听方法会返回一个boolean。...当它为false时,就会触发Click事件,当它为true时,便不会触发。我们希望在点击的时候触发点击事件,在拖动的时候实现移动效果的Touch事件。   ...这样做会出现很难触发点击事件拖动事件太容易触发。所以我们需要加点限制。在ACTION_MOVE中我们获得X、Y移动的距离。那么我们判断当期中一个的移动距离大于1的时,才执行key=true。...冲突得到较为完善的解决。

1.5K10

JS实现动态获取当前点击事件的id属性值

原本要实现的功能如下: 点击下图播放按钮,要弹窗播放对应的视频链接。...整个页面是通过ajax请求最新的4部视频进行填充完成,视频列表又是通过template-web.js插件补上去的,所以导致所有ID值都是一样的,一开始给按钮添加一个事件,结果是所有播放按钮都是播放第一个视频...于是,想了好多办法,又把ID属性给弄成动态的ajax请求的属性值,实现了每个id不一样,接下来,因为点击播放要调用一个方法,进行解析视频播放,拼接成API+视频链接的格式在新打开的弹窗进行展示。...具体可以看下图: 要实现点击不同按钮,并且按钮ID是动态从ajax请求获取的,还要添加点击视频拼接视频链接,参考了文章,可以获取点击按钮的id值,然后使用button,将链接放在value中 Dom

25.6K20

JavaScript 技巧篇-js增加延迟时间解决单击双击事件冲突,双击事件触发单击事件

js 的单双击事件同时存在会有一个问题:双击事件会同时触发单击事件,两个事件存在冲突。 我们加一个延迟时间就能很好的解决这个问题。...原理: 当接收到第一个点击时,我们先把单击事件存储在这个是全局变量 click_store 里,如果 0.3 秒内没有接收到双击事件,就去执行它,如果接收到了,我们把它清理掉,然后去执行双击事件。...var click_store // 定义一个全局变量存储单击触发事件 document.addEventListener('click', deal_click); document.addEventListener...dblclick', deal_dblclick); function deal_click(e){ click_store = setTimeout(function(e){ // 单击触发事件...,0.3s延迟 ... },300); } function deal_dblclick(e){ // 单击事件清理 clearTimeout(click_store); // 双击触发事件

5.9K30

【Android 事件分发】ItemTouchHelper 实现拖动排序

事件传递机制 七 ) 【Android 事件分发】ItemTouchHelper 简介 ( 拖动/滑动事件 | ItemTouchHelper.Callback 回调 ) 【Android 事件分发...实现拖动排序 ( 设置滑动方向 | 启启用长按拖动功能 | 拖动距离判定 | 设置拖动触发操作 ) ---- 文章目录 Android 事件分发 系列文章目录 一、ItemTouchHelper.Callback...此处设置上下拖动事件 int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN; // 设置滑动方向, 此处设置左右侧滑事件..., 此处设置上下拖动事件 int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN; // 设置滑动方向, 此处设置左右侧滑事件..., 此处设置上下拖动事件 int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN; // 设置滑动方向, 此处设置左右侧滑事件

2K10
领券