首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何为jQuery事件附加一些数据进行冒泡?

如何为jQuery事件附加一些数据进行冒泡?
EN

Stack Overflow用户
提问于 2018-08-24 01:21:41
回答 2查看 47关注 0票数 1

要展示我想要实现的目标,最简单的方法是创建一个简单的示例:

代码语言:javascript
复制
$("#button-1").click(function (e) { e.data = { flag: true } });
$("#button-2").click(function (e) { e.data = { flag: false } });

$(window).click(function (e) { $("p").html(JSON.stringify(e.data)) });
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<button id='button-1'>button 1</button>
<button id='button-2'>button 2</button>

<p></p>

当我将任何东西附加到事件时,它会在冒泡到窗口后消失。有没有办法保存它?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-08-24 01:39:39

我现在不能告诉你为什么它不能那样工作,我需要首先检查jQuery的源代码。

但是你可以把它连接到originalEvent上。但我可能会使用比data更具体的名称,以避免命名冲突。

代码语言:javascript
复制
$("#button-1").click(function (e) { e.originalEvent.data = { flag: true } });
$("#button-2").click(function (e) { e.originalEvent.data = { flag: false } });

$(window).click(function (e) { $("p").html(JSON.stringify(e.originalEvent.data)) });
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<button id='button-1'>button 1</button>
<button id='button-2'>button 2</button>

<p></p>

票数 2
EN

Stack Overflow用户

发布于 2018-08-24 01:47:06

为什么不简单地将事件附加到父事件,并根据触发事件的target来处理数据呢?请看下面过于简化的代码片段(可能不需要一直到window,但这应该会给你一个想法)。

代码语言:javascript
复制
$(window).click(function (event) {
  if (event.target.id == 'button-1') {
    event.data = { flag: true };
  } else if (event.target.id == 'button-2') {
    event.data = { flag: false };
  }
  
  $('p').html(JSON.stringify(event.data));
});
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button id='button-1'>button 1</button>
<button id='button-2'>button 2</button>
<p></p>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51991187

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档