- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 YUI 阻止 JavaScript 事件继续传播。以下是演示问题的一些最小 HTML 和一些最小 JavaScript:
HTML:
<a href="#foo" onClick="fooClickTest()" id="foo">foo</a>
<a href="#bar" id="bar">bar</a>
JavaScript:
function fooClickTest(e) {
alert('fooClickTest');
YAHOO.util.Event.addListener('bar', 'click', barClickTest1);
YAHOO.util.Event.addListener('bar', 'click', barClickTest2);
YAHOO.util.Event.addListener('bar', 'click', barClickTest3);
YAHOO.util.Event.preventDefault(e);
}
function barClickTest1(e) {
alert('barClickTest1');
YAHOO.util.Event.preventDefault(e);
}
function barClickTest2(e) {
alert('barClickTest2');
YAHOO.util.Event.preventDefault(e);
YAHOO.util.Event.stopEvent(e);
// Also tried:
// YAHOO.util.Event.stopPropagation(e);
// and:
// if (e.stopPropagation) {
// e.stopPropagation();
// } else {
// e.cancelBubble = true;
// }
}
我希望发生的是用户可以单击 foo
来添加三击处理程序,然后单击 bar
。然后,用户将看到两个警报,barClickTest1
和 barClickTest2
。相反,所有三个警报都会发生。 YAHOO.util.Event.stopEvent(e)
没有达到我的预期,即阻止事件传播到 barClickTest3
。
我已经在 Firefox 3.0.7 和 Safari 3.2.1 中测试了我的代码。正如您在上面看到的,我还尝试了 YAHOO.util.Event.stopPropagation(e)
和 e.stopPropagation()
。他们都没有成功。
这显然是一个人为的例子,尽管它确实说明了问题。在真正的解决方案中,我只会在满足某些条件时阻止事件传播。
我对 JavaScript 事件的理解是不是一团糟?我如何实现我的目标?
最佳答案
这没有像您预期的那样工作,因为:
YAHOO.util.Event.preventDefault()
只是告诉浏览器不要执行与元素关联的默认操作,在本例中,导航到 anchor 上的 href
属性。YAHOO.util.Event.stopPropagation()
取消父元素上的事件冒泡和触发事件处理程序。YAHOO.util.Event.stopEvent()
只需调用 preventDefault
和 stopEvent
。如果不编写额外的代码,就无法阻止触发单个元素上的某些事件监听器,即使可以,也无法保证事件监听器的触发顺序。
您需要将代码重写为单个事件处理程序,以便能够控制与第三个点击处理程序关联的代码是否会执行。
关于javascript - YAHOO Event.stopEvent 事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/675472/
我正在使用 Yahoo! 创建一些 RSS!管道,但更新间隔太长。我怎样才能改变它?如果不能改变,究竟是多久? 最佳答案 管道文档说它honors the standard HTTP expirati
我有一项使用 Yahoo!财务表yahoo.finance.xchange .今天早上我注意到它已经停止工作,因为突然 Yahoo!开始返回一个错误说: { "error": { "l
我正在尝试将 yql 用于雅虎财务数据。我检查了 YQL 控制台上的 Show Community Table 以查看 Yahoo 标签下的数据库。 我发布了示例 yql: https://devel
我正在尝试使用如下链接向 Yahoo 授权: https://api.login.yahoo.com/oauth2/request_auth?client_id=dj0yJmk9ZHNUWExxZmh
我想获取 Yahoo! 中给定交易品种的关键统计数据金融。 我找到了几种使用 Yahoo Finance API 获取统计数据的方法。例如获取Apple的名称(n),ask(a),bid(b),mar
如何从 Yahoo Weather API 获取 3,5 或 7 天的天气预报,而不仅仅是今天和明天? http://weather.yahooapis.com/forecastrss?w=locat
我的站点上运行着 Yahoo Pipe,Romneyomics它使用来自 Delicious 和 Topsy 的饲料。Delicious 提要不提供“描述”字段,但 Topsy 提供,并且不仅仅是一个
我目前正在编写一个 JAVA 应用程序,我需要在其中访问来自用户 Yahoo 电子邮件的以下信息(以显示给他们)。 YQL 看起来像是一种“快速简便的方法”,但事实证明它更加困难。我运行的所有测试都在
我上周开发并测试了这个 API。今天,我注意到即使从示例查询中我也没有收到任何结果。 https://developer.yahoo.com/yql/console/?q=show%20tables&
我使用 Yahoo BOSS 的时间很短。这是一个简单的搜索 API,但拼写建议支持确实不那么强大。周围的人是否有任何关于在 BOSS 上获得更好的拼写建议的想法。 最佳答案 不幸的是,甚至在几年后,
我正在寻找一种允许雅虎应用程序通过 IMAP 读取用户电子邮件的方法。它适用于旧应用程序(在 Yahoo Mail API 已弃用之前创建),但尝试访问新应用程序的 IMAP 给我一个错误 [AUTH
我正在开发一个使用 Yahoo OAuth 的应用程序。 OAuth 一直运行良好,但我刚刚在 Yahoo 注册了我的域,现在它不允许我在本地开发时使用 OAuth,因为 “不允许自定义端口或主机未使
对于我们的生产应用程序,我们在雅虎帐户上设置了 API。我们得到消费者 key 和消费者 secret 。 当用户点击访问来自 yahoo 的联系人时,我们收到 401 Forbidden 错误。Om
我正在使用 OAuth 2.0 规范检索梦幻足球数据,其方式与本网站使用它的方式相同:http://yfantasysandbox.herokuapp.com/resource/user/game_t
我尝试按照 read.csv("http://ichart.finance.yahoo.com/table.csv?s=SPY") Not Working 的建议同时使用 http 和 https .
我正在检索雅虎金融公司的数据,我成功地获得了公司的股票数据。除了基本数据外,我还尝试检索同一家公司的关键统计数据。下图是我需要的关键统计字段。 我正在使用 yahoo web service api
我想使用 Beautiful Soup 和 urllib 从 python 脚本对雅虎搜索引擎进行基本查询。我对谷歌也做了同样的事情,这相当容易,但事实证明雅虎有点困难。查询雅虎搜索引擎的最小示例脚本
我最近一直在开发 Ruby on Rails 应用程序。我们使用 Yahoo Web Player 来播放我们的音频和视频文件。它工作得非常好,特别是对于不允许使用 Flash 的平板电脑和智能手机。
我想知道如果我们谈论压力单位,“in”代表什么?我相信 mb = mili bars = hPa。有了这个假设,就有些奇怪了。我分别使用 u=c 和 u=f 取了 2 个不同的 WOEID,结果如下
我需要一种方法来使用 javascript 返回某个城市的当前天气吗?我最好使用哪个 API?或者是否有任何其他应用程序可以使用 ajax 请求来获取当前天气? GeoPlanit 需要一个 appi
我是一名优秀的程序员,十分优秀!