Js实现移动端长按事件

JavaScript010

Js实现移动端长按事件,第1张

最近在做一个移动端的项目,其中有一个收藏列表,其中包含几个事件。

1.点击跳转详情页。

2.长按显示遮罩层和删除按钮

3.点击删除按钮,删除此项。

下面会详细介绍我处理此问题时所出现的问题,及处理方法(本文基于jQuery)

首先我对列表添加了长按事件,添加完之后,发现我的长按事件已经可以成功执行了。但是却出现了新的问题:

这个问题好处理,只需添加一个变量,来判断是否为长按事件

这样上面的问题就完美解决了。

接下来就是给遮罩层上的删除按钮添加事件

但是在这里就发现了新的问题

所以就需要一个新的事件来覆盖原本的事件

然后,整个点击跳转,长按显示删除,删除事件,就已经完美解决了。

但是,在移动端查看的时候就会发现正常的滚动事件被preventDefault屏蔽了。

此处有两种解决方式:

1.删除 e.preventDefault()

删除preventDefault有可能会出现其它情况,不过我暂时没发现如果出现其它情况,可使用下面的方法

删除的点击事件也是如此

By : Yimi-shan

最近在做一个项目,点击一个按钮,弹出一张图片,长按图片保存图片,点击图片图片隐藏。

在做的时候发现,当我们长按图片的时候也会执行点击图片的事件,这时候我们就需要判断长按事件和点击事件了。

html

js

在javascript中,可以为某个元素指定事件,指定的方式有以下三种:

1、在html中,使用onclick属性

2、在javascript中,使用onclick属性

(1)注意函数名没有双引号。

3、在javascipt中,使用addEvenListener()方法

三种方法的比较

(1)在第二、三种方法中,可以向函数传入一个event对象,并读取其相应属性,而方法一不可以。

一些语法细节

(1)在第一种方法中,onclick大小写无关,但在第二种方法中,必须使用小写。因为HMTL对大小写不敏感,而JS则会区分大小写。

(2)在第二、三种方法中,指定函数名时没有双引号,而第一种作为一个HTML属性,需要双引号。

(3)第一种方法需要括号,第二、三种不需要。

onclick="clickHandler()"

document.getElementById("jsOnClick").onclick = clickHandler2

document.getElementById("adEventListener").addEventListener("click",clickHandler2)