• 巧用 tabindex 属性解决 iframe 环境下鼠标点击元素之外的监听事件


    场景如下:用 js 模拟了一个右键菜单,在鼠标点击到右键菜单之外的区域时,关闭菜单。

    之前的处理方案是,打开右键菜单时在 body 上注册一个监听事件,addEventListener('click', closeMenu) 。但是这种方式在遇到 iframe 时不起作用了。

    当点击到 iframe 区域时,不会触发绑定在 body 上的点击事件。

    所以我们就在右键菜单视图上设置一个 tabindex 属性,在打开菜单的时候,调用元素的 focus 方法,使元素处于焦点状态,当点击其他区域的时候,会触发元素的失焦事件,此时调用关闭菜单的方法。

      • if="visible" ref="contextmenu" tabindex="-1" @blur="closeMenu">
    1. <li>...li>
  • <script setup lang="ts">
  • const contextmenu = ref(null)
  • const visible = ref(false)
  • function openMenu() {
  • visible.value = true
  • // ...
  • nextTick(() => {
  • if(contextmenu.value) {
  • contextmenu.value?.focus()
  • }
  • })
  • }
  • function closeMenu() {
  • visible.value = false
  • }
  • script>
  • 相关阅读:
    C# 泛型
    JAVA主要面向哪个方面?
    51单片机学习/直流电机驱动
    Bootstrap中的栅格系统
    AIGC ChatGPT 4 将数据接口文件使用Python进行入库Mysql
    【课程总结】Day11(中):手势图像识别实战(Vgg16和ResNet)
    Android | ListView 长按删除列表项【学习笔记】
    Go语言中的init函数: 特点、用途和注意事项
    为什么多数情况下GPT-3.5比LLaMA 2更便宜?
    关于spring的xml文件中的xmlns,xsi,schemaLocation
  • 原文地址:https://blog.csdn.net/weixin_38728902/article/details/134532062