我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么在html5中模拟长按事件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么在html5中模拟长按事件

本篇文章为大家展示了怎么在html5中模拟长按事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

思路

  • 放弃click事件,通过判断按的时长来决定是单击还是长按

  • 使用touchstart和touchend事件

  • 在touchstart中开启一个定时器,比如在700ms后显示一个长按菜单

  • 在touchend中清除这个定时器,这样如果按下的时间超过700ms,那么长按菜单已经显示出来了,清除定时器不会有任何影响;如果按下的时间小于700ms,那么touchstart中的长按菜单还没来得及显示出来,就被清除了。

由此我们可以实现模拟的长按事件了。

上代码

请把重点放在JS上,这里贴出来完整的代码是为了方便大家看个仔细,代码可以拷贝直接看效果
css中大部分只是做了样式的美化,还有一开始让删除按钮隐藏起来

HTML:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta http-equiv="X-UA-Compatible" content="ie=edge">    <title>Document</title>    <link rel="stylesheet" type="text/css" href="./longpress.css" /></head><body>    <div class="container">        <div class="label" id="label">长按我</div>        <div class="delete_btn">删除</div>    </div>    <script class="lazy" data-src="./longpress.js"></script></body></html>

JS

let timer = nulllet startTime = ''let endTime = ''const label = document.querySelector('.label')const deleteBtn = document.querySelector('.delete_btn')label.addEventListener('touchstart', function () {  startTime = +new Date()  timer = setTimeout(function () {    deleteBtn.style.display = 'block'  }, 700)})label.addEventListener('touchend', function () {  endTime = +new Date()  clearTimeout(timer)  if (endTime - startTime < 700) {    // 处理点击事件    label.classList.add('selected')  }})

CSS

.container {    position: relative;    display: inline-block;    margin-top: 50px;}.label {    display: inline-block;    box-sizing: border-box;    width: 105px;    height: 32px;    line-height: 32px;    background-color: #F2F2F2;    color: #5F5F5F;    text-align: center;    border-radius: 3px;    font-size: 14px;}.label.selected {    background-color: #4180cc;    color: white;}.delete_btn {    display: none;    position: absolute;    top: -8px;    left: 50%;    transform: translateX(-50%) translateY(-100%);    color: white;    padding: 10px 16px;    background-color: rgba(0, 0, 0, .7);    border-radius: 6px;    line-height: 1;    white-space: nowrap;    font-size: 12px;}.delete_btn::after {    content: '';    width: 0;    height: 0;    border-width: 5px;    border-style: solid;    border-color: rgba(0, 0, 0, .7) transparent transparent transparent;    position: absolute;    bottom: -9px;    left: 50%;    transform: translateX(-50%);}

ps: touchstart和touchend只有在移动端设备上才有用,如果要看代码示例的话请:

  1. 用chrome

  2. F12打开调时窗

  3. 切换到模拟移动设备

即点击如下图:

怎么在html5中模拟长按事件

上述内容就是怎么在html5中模拟长按事件,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么在html5中模拟长按事件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么在html5中模拟长按事件

本篇文章为大家展示了怎么在html5中模拟长按事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。思路放弃click事件,通过判断按的时长来决定是单击还是长按使用touchstart和touchend
2023-06-09

按钮点击事件与长按事件在Android项目中的区别是什么

本篇文章给大家分享的是有关按钮点击事件与长按事件在Android项目中的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 Android 自定义按钮点击事件和长按事件对
2023-05-31

怎么在Html5中实现手机摇一摇事件

怎么在Html5中实现手机摇一摇事件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。