首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS篇(028)-移动端 click 事件、touch 事件、tap 事件的区别

参考答案: 1.click 事件在移动端会有 200-300ms 的延迟,主要原因是苹果手机在设计时,考虑到用户在浏览网页时需要放大,所以,在用户点击的 200-300ms 之后,才触发 click,...mouseover mouseup 的触发 3.tap 事件在移动端,代替 click 作为点击事件,tap 事件被很多框架(如 zepto)封装,来减少这延迟问题, tap 事件不是原生的,所以是封装的...display: none,而从上面的 tap 可以看出,有 touchstart、touchend,所以会 300ms 之后触发 click 事件,而 z-index 已经消失了,所以,触发了下面的...a 的 click 事件,注意: 我们认为 a 标签默认是绑定了 click 事件的。...(2)添加一个延迟。 (1)直接引入 fastclick 库。

6K40

Android触摸事件和mousedown、mouseup、click事件之间的关系

然而当option没有元素时,就不希望弹出下拉(比如在某些浏览器,点击select会默认出一个罩层效果,而此时没有数据选择的话,弹出比较不友好)。...首先想到是利用click事件控制,发现仍然会有下拉出现…实际这个是mousedown事件控制的。 这里就说明下click和mousedown、mouseup。...规范要求,只有在同一个元素上相继触发 mousedown 和 mouseup 事件,才会触发 click 事件;如果 mousedown 或 mouseup 的一个被取消,就不会触发 click 事件...return false后,就不会弹出下拉或者罩层了… 这里再介绍下鼠标的各个事件: DOM3 级事件定义了9个鼠标事件,简介如下。...从技术上说,这个事件并不是DOM2级事件规范规定的,但鉴于它得到了广泛支持,所以DOM3 级事件将其纳入了标准。 mousedown:在用户按下了任意鼠标按钮时触发。不能通过键盘触发这个事件

2.7K30

代码触发,手动触发touchstart事件,touch事件click事件,自定义事件

工作中有时候会用到需要用代码去手动触发某个事件或者是自定义事件,通常触发click事件的做法为eleme.click(),遇到touchstart就行不通了。...可以使用以下方式 // 创建事件. var event = document.createEvent('Events'); // 初始化一个点击事件,可以冒泡,无法被取消 event.initEvent...('touchstart', true, false); // 设置事件监听. elem.addEventListener('touchstart', function (e) { //...e.target 就是监听事件目标元素 }, false); // 触发事件监听 elem.dispatchEvent(event); initEvent已经从 Web 标准删除,虽然一些浏览器目前仍然支持它...'touchstart', function (e) { ... }, false); // 触发event. elem.dispatchEvent(event); Event构造函数也可以使用自定义事件

4.7K30

js事件(event)

当然我们也可以不给事件绑定处理方法,也就是说当此事件发生的时候,什么也不需要做,事件常有,而事件上绑定的方法不一定有, 我们给页面的元素的某个事件绑定处理方法的时候。...,如果想把这些默认行为取消了,相应的js代码如下: a.onclick = function(){return false}//方法里加个 return false,就是组织超链接点击时的跳转行为了;...,但是性能不是最优的; return false;//阻止超链接的默认行为; } } 以下用事件委托实现 事件委托:事件委托就是利用事件传播的机制,无论哪一个页面元素,他的click事件都会最终传播到document...上;这样,只需要在document上处理click事件即可; document.onclick = function(e){ e = e||window.event; var target = e.target...在W3C的标准是在同一事件上,先绑定的方法先执行,并且不能重复绑定同一个方法在同一个事件上,但是IE6、7、8,如果绑定的方法少于9个,执行的顺序是相反的,超过9个,执行顺序就是混乱的,这些IE的问题都是比较严重的

6.7K30

jQuery 双击事件(dblclick)时,不触发单击事件(click)

出处:jQuery 双击事件(dblclick)时,不触发单击事件(click) 在jQuery的事件绑定,执行双击事件(dblclick)时能触发两次单击事件(click)。...即一个标签元素(如div等),如果元素同时绑定了单击事件(click)和双击事件(dblclick),那么执行单击事件(click)时,不会触发双击事件(dblclick), 执行双击事件(dblclick...)时却会触发两次单击事件(click)。...mouseout,click,dblclick; 在双击事件(dblclick),触发的两次单击事件(click),第一次的单击事件(click)会被屏蔽掉,但第二次不会。...也就是说双击事件(dblclick)会返回一次单击事件(click)结果和一次双击事件(dblclick) 结果。而不是一次双击事件(dblclick)结果和两次单击事件结果(click)。

5.1K30

jQuery源码解析之click()的事件绑定

而下到达目标节点的过程,浏览器会检测 针对该事件的 监听器(用来捕获事件),并运行捕获事件的监听器。...(2)阶段二:Target 目标 浏览器找到监听器后,就运行该监听器 (3)阶段三:Bubbling 冒泡(目标到祖) 在事件自下而上(document->html->body->xxx)到达目标节点的过程...) 方法( trigger() 放到下篇讲 ) 三、$().on() 作用: 在被选元素及子元素上添加一个或多个事件处理程序 源码: //绑定事件的方法 //源码5812行 jQuery.fn.extend...( { //在被选元素及子元素上添加一个或多个事件处理程序 //$().on('click',function()=<{}) //源码5817行 on: function...,也就是说,click()/on() 的本质是 element.addEventListener() 事件,前面一系列的铺垫,都是在为目标 jQuery 对象添加必要的属性。

1.7K20

移动端click事件300ms延迟

移动端click 事件延迟300ms 一般情况下,如果没有经过特殊处理,移动端浏览器在派发点击事件的时候,通常会出现300ms左右的延迟。...chrome 32+,如果设置了上述meta标签,那浏览器就可以认为该网站已经对移动端做过了适配和优化,就无需双击缩放操作了。...所以,接下去我们要来看一些专门针对 300 毫秒延迟而生的解决方案 zepto等库的 tap事件 zepto 的touch模块自定义了tap事件,用于代替click事件,表示一个轻击操作。...基本原理:FastClick的实现原理是在检测到touchend事件的时候,会通过DOM自定义事件立即出发模拟一个click事件,并把浏览器在300ms之后真正的click事件阻止掉。...为了防止原生的click被触发,这里还通过event.preventDefault()屏蔽了原生的click事件

2.7K21

移动端touch事件影响click事件以及在touchmove添加preventDefault导致页面无法滚动的解决方法

页面的超链接点击没反应了!!!给其他地方加的click事件也不触发了!!!...我在touchstart调用了event.preventDefault方法,是不是让浏览器误以为没有触发touchstart事件,只触发了touchend事件,所以没有触发click事件呢?...原来touchmove添加event.preventDefault方法之后会阻止浏览器默认的滚动。。。...总结一下: 在QQ和微信(当然还包括其他浏览器,不过我没测试过)如果有需要用到touch事件做的特效一定要在touchstart或者touchmove添加event.preventDefault()...在touchstart如果有event.preventDefault()方法, 将不会触发click事件和a标签方法。在这里可以使用tap代替click,但是a标签的话就不太方便了。

3.2K20
领券