iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在html5中模拟长按事件
  • 643
分享到

怎么在html5中模拟长按事件

2023-06-09 13:06:08 643人浏览 独家记忆
摘要

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

本篇文章为大家展示了怎么在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 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中模拟长按事件,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 怎么在html5中模拟长按事件

本文链接: https://www.lsjlt.com/news/256208.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 怎么在html5中模拟长按事件
    本篇文章为大家展示了怎么在html5中模拟长按事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。思路放弃click事件,通过判断按的时长来决定是单击还是长按使用touchstart和touchend...
    99+
    2023-06-09
  • 在uniapp中实现长按事件(屏蔽点击事件)
    在uniapp中实现长按事件(屏蔽点击事件) 问题 在uniapp使用官方提供的长按点击事件时会触发点击事件 点击我 longpress() {console.log("长按事件");}, ...
    99+
    2023-09-04
    小程序 web app
  • VUE中怎么实现一个长按事件
    VUE中怎么实现一个长按事件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 需求一:长按数字累加或者累减HTML:<div...
    99+
    2024-04-02
  • 按钮点击事件与长按事件在Android项目中的区别是什么
    本篇文章给大家分享的是有关按钮点击事件与长按事件在Android项目中的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 Android 自定义按钮点击事件和...
    99+
    2023-05-31
    android 别是 roi
  • layui如何模拟table表格中的选中按钮选中事件
    这篇文章给大家分享的是有关layui如何模拟table表格中的选中按钮选中事件的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、问题不操作页面,实现table表格中的checkb...
    99+
    2024-04-02
  • HTML5中怎么实现video 事件
    HTML5中怎么实现video 事件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 1、获取视频时间长度 当视...
    99+
    2024-04-02
  • HTML5中拖放事件怎么用
    这篇文章主要介绍HTML5中拖放事件怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!浏览器支持Internet Explorer 9、Firefox、Opera 12、Chrom...
    99+
    2024-04-02
  • javascript中怎么触发模拟鼠标点击事件
    本篇文章为大家展示了javascript中怎么触发模拟鼠标点击事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。事件触发器就是用来触发某个元素下的某个事件,IE下f...
    99+
    2024-04-02
  • 怎么在Html5中实现手机摇一摇事件
    怎么在Html5中实现手机摇一摇事件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。<template>  <div id=&...
    99+
    2023-06-09
  • html5怎么模拟平抛运动
    这篇文章主要讲解了“html5怎么模拟平抛运动”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“html5怎么模拟平抛运动”吧!物体以一定的初速度沿水平方向抛出...
    99+
    2024-04-02
  • vue中如何模拟点击事件
    在vue中模拟点击事件的方法:1.新建vue.js项目;2.添加按钮,设置ref属性;3.添加@click属性绑定事件;4.使用this方法触发事件;具体步骤如下:首先,在vue-cli中创建一个vue.js项目;vue create pr...
    99+
    2024-04-02
  • 怎么在Html5中实现百度地图的点击事件
    怎么在Html5中实现百度地图的点击事件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。根据百度地图官方解释,在移动端 H5 页面中可监听下面这 4 个事件:touchsta...
    99+
    2023-06-09
  • 怎么在html5中判断触摸事件的滑动方向
    这期内容当中小编将会给大家带来有关怎么在html5中判断触摸事件的滑动方向,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。TouchEventTouchEvent 是一类描述手指在触摸平面(触摸屏、触摸板等...
    99+
    2023-06-09
  • 如何在Html5中监听返回事件
    本篇文章为大家展示了如何在Html5中监听返回事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。在使用MUI框架的时候,我们经常会用到一个头部带有.mui-action-back的class<...
    99+
    2023-06-09
  • Laravel模型事件和模型事件在Trait中如何使用
    这篇文章主要介绍“Laravel模型事件和模型事件在Trait中如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Laravel模型事件和模型事件在Trait中如何使用”文章能帮助大家解决问题。...
    99+
    2023-07-05
  • autojs模仿QQ长按弹窗菜单怎么实现
    本篇内容主要讲解“autojs模仿QQ长按弹窗菜单怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“autojs模仿QQ长按弹窗菜单怎么实现”吧!分析弹框菜单圆角列表, 类似grid箭头位于...
    99+
    2023-07-05
  • html5中touch事件有什么用
    这篇文章给大家分享的是有关html5中touch事件有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。规范 这里我们介绍几种普及得比较好的触摸事件,你可以在绝大多数现代浏览器...
    99+
    2024-04-02
  • Html5中hashchange、pageshow和pagehide事件怎么应用
    本篇内容主要讲解“Html5中hashchange、pageshow和pagehide事件怎么应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Html5中ha...
    99+
    2024-04-02
  • html5怎么实现模拟平抛运动
    本文小编为大家详细介绍“html5怎么实现模拟平抛运动”,内容详细,步骤清晰,细节处理妥当,希望这篇“html5怎么实现模拟平抛运动”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。...
    99+
    2024-04-02
  • html5的touch事件怎么实现
    今天小编给大家分享一下html5的touch事件怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作