- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我只是想我可以在 ul 元素上使用事件委托(delegate),这样点击任何 li 元素都会冒泡到 ul。然后由 ul 的 event.target 捕获以获取正确的 li 元素并根据我对 li 的需要进行处理。这就是我学习的方式。但是点击 contact li 元素并没有像预期的那样发出警报。请在这件事上给予我帮助。我的公司强制我使用事件委托(delegate)。这就是为什么它如此重要。
HTML
<!doctype html>
<html>
<head>
<title>Title</title>
<link rel="stylesheet" type="text/css" href="style.css" >
<script src="JavaScript.js"></script>
</head>
<body>
<div>
<ul id="nav">
<li id="click"><a href="#">Contact</a></li>
<li> <a href="#">Blog</a></li>
<li> <a href="#">Work</a></li>
<li> <a href="#">About</a></li>
<li> <a href="#">Home</a></li>
</ul>
</div>
</body>
</html>
JS
var list = document.getElementById("nav");
list.addEventListener("click", function(event) {
switch(event.target.id) {
case "click":
alert("haha");
break;
}, false);
CSS
body {
margin: 0;
}
#nav {
list-style-type: none;
margin: 0;
padding: 0;
}
#nav li {
width: 20%;
float: left;
text-align: center;
display: inline;
}
#nav li a {
line-height: 40px;
display: block;
padding: 0.5em 5px;
text-decoration: none;
font-weight: bold;
color: #F2F2F2;
-webkit-box-shadow: 3px 3px 3px rgba(51,51,51,0.3);
box-shadow: 3px 3px 3px rgba(51,51,51,0.3);
}
#nav a:link, #nav a:visited {
background-color: #071726;
}
#nav a:hover, #nav a:active, #nav a:focus {
background-color: #326773;
}
最佳答案
您的主要问题是您的事件处理程序中存在语法错误,您缺少开关
的。 (使用一致的缩进有助于避免此类错误。)
那么你的问题是 event.target
不是你想的那样。 event.target
是被点击的实际元素。在您的情况下,被点击的实际元素很可能是 a
元素(链接)。
因此,您要做的是查看从被点击元素到您点击的元素(将是 this
)的沿袭,寻找处于该级别的元素你想要(在你的例子中,一个 li
):Live Example | Source
var list = document.getElementById("nav");
list.addEventListener("click", function(event) {
// Start with the element that was clicked
var li = event.target;
// You may want `event.preventDefault();` here
// If the element exists, it isn't the list on which we hooked
// the event, and its tag name isn't LI, go to the parent
// element instead.
while (li && li !== this && li.tagName.toUpperCase() !== "LI") {
li = li.parentNode;
}
// If we got an LI, use it
if (li) {
// OR you may want `event.preventDefault();` here
switch(li.id) {
case "click":
alert("haha");
// OR you may want `event.preventDefault();` here
break;
}
}
}, false);
此外,请确保上面的代码位于 HTML 中导航列表下方的 script
元素中,或者位于 onload
中handler(推荐前者,把脚本放在最后即可)。
最后:由于链接的 href
只是 "#"
,我猜您实际上并不希望浏览器访问该链接(因为将向上滚动到页面顶部)。如果是这种情况,您需要在处理程序中添加对 event.preventDefault()
的调用。我已经在上面的几个地方注明了您可能需要它的地方,这取决于您是总是想要阻止链接被跟踪,还是仅在某些情况下。
旁注:虽然您当然可以自己完成这项工作,但您可以通过使用像 jQuery 这样的好库来重用其他人的工作。 , YUI , Closure , 或 any of several others .例如,在 jQuery 中,它看起来像这样:
$("#nav").on("click", "li", function(event) {
// Possibly with `event.preventDefault();` here
switch (this.id) {
case "click":
alert("haha");
// OR possibly with `event.preventDefault();` here
break;
}
});
其他图书馆也有类似的功能。
关于JavaScript 事件委托(delegate)未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19475534/
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
var urlsearch = "http://192.168.10.113:8080/collective-intellegence/StoreClicks?userid=" + userId +
我有一个非常奇怪的问题,过去两天一直让我抓狂。 我有一个我试图控制的串行设备(LS 100 光度计)。使用设置了正确参数的终端(白蚁),我可以发送命令(“MES”),然后是定界符(CR LF),然后我
我目前正试图让无需注册的 COM 使用 Excel 作为客户端,使用 .NET dll 作为服务器。目前,我只是试图让概念验证工作,但遇到了麻烦。 显然,当我使用 Excel 时,我不能简单地使用与可
我开发了简单的 REST API - https://github.com/pavelpetrcz/MandaysFigu - 我的问题是在本地主机上,WildFly 16 服务器的应用程序运行正常。
我遇到了奇怪的情况 - 从 Django shell 创建一些 Mongoengine 对象是成功的,但是从 Django View 创建相同的对象看起来成功,但 MongoDB 中没有出现任何数据。
我是 flask 的新手,只编写了一个相当简单的网络应用程序——没有数据库,只是一个航类搜索 API 的前端。一切正常,但为了提高我的技能,我正在尝试使用应用程序工厂和蓝图重构我的代码。让它与 pus
我的谷歌分析 JavaScript 事件在开发者控制台中运行得很好。 但是当从外部 js 文件包含在页面上时,它们根本不起作用。由于某种原因。 例如; 下面的内容将在包含在控制台中时运行。但当包含在单
这是一本名为“Node.js 8 the Right Way”的书中的任务。你可以在下面看到它: 这是我的解决方案: 'use strict'; const zmq = require('zeromq
我正在阅读文本行,并创建其独特单词的列表(在将它们小写之后)。我可以使它与 flatMap 一起工作,但不能使它与 map 的“子”流一起工作。 flatMap 看起来更简洁和“更好”,但为什么 di
我正在编写一些 PowerShell 脚本来进行一些构建自动化。我发现 here echo $? 根据前面的语句返回真或假。我刚刚发现 echo 是 Write-Output 的别名。 写主机 $?
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我将一个工作 View Controller 类从另一个项目复制到一个新项目中。我无法在新项目中加载 View 。在旧项目中我使用了presentModalViewController。在新版本中,我
我对 javascript 很陌生,所以很难看出我哪里出错了。由于某种原因,我的功能无法正常工作。任何帮助,将不胜感激。我尝试在外部 js 文件、头部/主体中使用它们,但似乎没有任何效果。错误要么出在
我正在尝试学习Flutter中的复选框。 问题是,当我想在Scaffold(body :)中使用复选框时,它正在工作。但我想在不同的地方使用它,例如ListView中的项目。 return Cente
我们当前使用的是 sleuth 2.2.3.RELEASE,我们看不到在 http header 中传递的 userId 字段没有传播。下面是我们的代码。 BaggageField REQUEST_I
我有一个组合框,其中包含一个项目,比如“a”。我想调用该组合框的 Action 监听器,仅在手动选择项目“a”完成时才调用。我也尝试过 ItemStateChanged,但它的工作原理与 Action
你能看一下照片吗?现在,一步前我执行了 this.interrupt()。您可以看到 this.isInterrupted() 为 false。我仔细观察——“这个”没有改变。它具有相同的 ID (1
我们当前使用的是 sleuth 2.2.3.RELEASE,我们看不到在 http header 中传递的 userId 字段没有传播。下面是我们的代码。 BaggageField REQUEST_I
我正在尝试在我的网站上设置一个联系表单,当有人点击发送时,就会运行一个作业,并在该作业中向所有管理员用户发送通知。不过,我在失败的工作表中不断收到此错误: Illuminate\Database\El
我是一名优秀的程序员,十分优秀!