RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 983467
Accepted
Дмытрык
Дмытрык
Asked:2020-05-20 18:05:57 +0000 UTC2020-05-20 18:05:57 +0000 UTC 2020-05-20 18:05:57 +0000 UTC

event.stopPropagation 的对立面。如何继续冒泡事件?

  • 772

有没有这样的方法?还是您需要创建自己的活动?

UPD
总的来说,我想在 Vue 组件上应用这个技巧,它没有时间处理数据,在点击和打开文件上传窗口之间(接受更改)。
但是,在一些异步操作之后需要解决进一步分发问题的情况下,例如,在服务器响应之后,这可能是必要的......

document.addEventListener('click', ()=>{
  console.log('Клик вспыл до документа')
})
const base = document.getElementById('base');
base.addEventListener("click", (e)=>{
  e.stopPropagation();
  setTimeout(()=>{
// как продолжить всплытие клика?
  })
})
body{
  display: flex;
  justify-content: center;
  height: 100vh;
  width: 100vw;
  overflow: hidden;
}
#base{
  height: 100px;
  width: 100px;
  border: 1px solid black;
}
 <div id="base"></div>

javascript
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    smellyshovel
    2020-05-20T19:20:28Z2020-05-20T19:20:28Z

    覆盖默认选项

    可以通过使用来防止打开文件选择对话框event.preventDefault()。你可以取消一个event.preventDefault()动作event.returnValue = true

    document.querySelector("input").addEventListener("click", async (event) => {
      event.preventDefault();
      event.returnValue = true;
    });
    <input type="file">

    returnValue但是,应该记住,如果执行了任何异步操作,那么在其完成后,将无法再使用. 为什么?因为事件很久以前就结束了,handler执行的是异步代码(在执行的时候事件已经不存在了)

    document.querySelector("input").addEventListener("click", async (event) => {
      event.preventDefault();
       
      new Promise((res) => {
        // симулируем асинхронную операцию
        setTimeout(res, 1000);
      }).then(() => {
        console.log("Асинхр. операция завершилась");
        event.returnValue = true;
      });
    });
    <input type="file">

    你的选择

    不幸的是,你想象的方式也行不通。原因2:首先 - 没有这样的(标准)方法(1)和(2) - 您仍在尝试与(已通过,已完成)事件异步交互。

    该怎么办?(工作版)

    最有可能的是,在另一个元素上发布自定义事件的选项将起作用(请参阅问题的评论),但是,有一些值得考虑的陷阱(另请参阅那里)。

    我绘制了一个似乎可行的示例(2 秒后打开一个对话框)。

    document.querySelector("#fake").addEventListener("click", async (event) => {
      event.preventDefault();
      
      new Promise((res) => {
        setTimeout(res, 2000);
      }).then(() => {
        document.querySelector("#real").click();
      });
    });
    <input type="file" id="fake">
    <input type="file" id="real" hidden>

    • 1
  2. Qwertiy
    2020-05-20T19:43:08Z2020-05-20T19:43:08Z

    有些事件可以以编程方式重复 - 例如click- 即使通过调用方法,事件也更复杂 - 通过dispatchEvent,但对于某些事件,它不会带来任何好处。

    document.querySelector('section').addEventListener('click', function (e) {
      console.log("Section clicked")
    })
    
    ~function () {
      var isReplay;
    
      document.querySelector('div').addEventListener('click', function (e) {
        if (!isReplay) {
          console.log("Div clicked by user")
          e.stopPropagation()
          setTimeout(function () {
            isReplay = true
            e.target.click()
            isReplay = false
          }, 1000)
        }
      })
    }()
    <section><div>123</div></section>

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    根据浏览器窗口的大小调整背景图案的大小

    • 2 个回答
  • Marko Smith

    理解for循环的执行逻辑

    • 1 个回答
  • Marko Smith

    复制动态数组时出错(C++)

    • 1 个回答
  • Marko Smith

    Or and If,elif,else 构造[重复]

    • 1 个回答
  • Marko Smith

    如何构建支持 x64 的 APK

    • 1 个回答
  • Marko Smith

    如何使按钮的输入宽度?

    • 2 个回答
  • Marko Smith

    如何显示对象变量的名称?

    • 3 个回答
  • Marko Smith

    如何循环一个函数?

    • 1 个回答
  • Marko Smith

    LOWORD 宏有什么作用?

    • 2 个回答
  • Marko Smith

    从字符串的开头删除直到并包括一个字符

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5