满口金牙 2022-07-04 16:09 采纳率: 91.1%
浏览 745
已结题

Vue 单击 事件,和双击事件,冲突,请教

我在DOM 绑了 单击 事件,还有 双击事件
下面这样写还是有点冲突。 当操作过快时,请教有什么更完美的 方案

/ 单击td
let timer: any = null
function inputFocus(event: any) {
  clearTimeout(timer)
  timer = setTimeout(() => {
    if (editState) return
    // 非编辑状态 点击则全选 input
    if (event.target.nodeName != 'TD') return
    sDOM = eDOM = endTd.value = startTd.value = event.target
    const inputDOM = (event.target as HTMLTableCellElement).children[0] as HTMLInputElement
    inputDOM.classList.add('input-focus')
    inputDOM.focus()
    inputDOM.select() // 输入自动 覆盖 原 input的内容
    document.removeEventListener('keydown', tdKeydown)  //绑定新事件函数前用removeEventListener移除上次的事件函数即可
    document.addEventListener('keydown', tdKeydown)
  }, 300);
}
// 双击 td 进入编辑状态
function cellEdit(event: any) {
  if (editState) return // 假如已经是编辑状态
  const inputDOM = (event.target as HTMLTableCellElement).children[0] as HTMLInputElement
  inputDOM.classList.remove('input-focus')
  inputDOM.style.pointerEvents = 'auto'
  cellRange.weight = '1px'
  nextTick(() => {
    inputDOM.focus()
    inputDOM.selectionStart = 300
  })
  // console.log(cellEdit, 2, inputDOM);
  editState = true
  clearTimeout(timer)
}
  • 写回答

6条回答 默认 最新

  • 关注

    你 单击 事件设置的延时触发时间太小了吧, 设置600试试
    测试事件延时时间300不行, 要设置600才可以

    <!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,chrome=1" />
        <title> 页面名称 </title>
    </head>
    <body>
    
    <input type="button" value="aaaaaaa" onclick="clickfunc();" ondblclick="dblclickfunc();" />
    <script type="text/javascript">
    let timer = null
    function clickfunc() {
      clearTimeout(timer)
      timer = setTimeout(() => {
          console.log("click");
      }, 600);
    }
    
    function dblclickfunc() {
        clearTimeout(timer)
        console.log("dblclick");
    }
    
    </script>
    
    </body>
    </html>
    
    

    如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 7月17日
  • 已采纳回答 7月9日
  • 创建了问题 7月4日

悬赏问题

  • ¥15 给我一个openharmony跑通webrtc实现视频会议的简单demo项目,sdk为12
  • ¥15 vb6.0使用jmail接收smtp邮件并另存附件到D盘
  • ¥30 vb net 使用 sendMessage 如何输入鼠标坐标
  • ¥15 关于freesurfer使用freeview可视化的问题
  • ¥100 谁能在荣耀自带系统MagicOS版本下,隐藏手机桌面图标?
  • ¥15 求SC-LIWC词典!
  • ¥20 有关esp8266连接阿里云
  • ¥15 C# 调用Bartender打印机打印
  • ¥15 我这个代码哪里有问题 acm 平台上显示错误 90%,我自己运行好像没什么问题
  • ¥50 C#编程中使用printDocument类实现文字排版打印问题