满口金牙 2022-07-04 15:26 采纳率: 91.5%
浏览 112
已结题

**Vue, keydown 重复监听的问题请教**

Vue, keydown 重复监听的问题请教

只在这写了一个 keydown 的 事件
onMounted(() => {
  window.oncontextmenu = function (e) { e.preventDefault() } 
  document.addEventListener('keydown', tdKeydown)
})


let aaxx =0
function tdKeydown(event: any) {
  console.log(aaxx++)    // 按一下 键, 这里打印执行了 n次,重新刷页面又好了
}

不在 onMounted 中 增加监听,在另一个函数中写
而且是先移除,再加,还是会出现重复监听的情况

 // 注: 这个函数会多次调用
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);
}

没明白错在哪

  • 写回答

3条回答 默认 最新

  • CSDN专家-showbo 2022-07-04 15:42
    关注

    测了没问题

    
        let aaxx = 0
        function tdKeydown(event) {
            console.log(aaxx++)    // 按一下 键, 这里打印执行了 n次,重新刷页面又好了
        }
        var timer, editState
        // 注: 这个函数会多次调用
        function inputFocus(event) {
            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).children[0]
                inputDOM.classList.add('input-focus')
                inputDOM.focus()
                inputDOM.select() // 输入自动 覆盖 原 input的内容
                document.removeEventListener('keydown', tdKeydown)  //绑定新事件函数前用removeEventListener移除上次的事件函数即可
                document.addEventListener('keydown', tdKeydown)
            }, 300);
        }
        x.addEventListener('dblclick', inputFocus)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事: