我已经创建了一个应该是联系人列表的div元素。它应该包含其他div。 我想要做的是在每个列表项目(每个内部div)上附加一个点击处理程序。 但点击处理程序永远不会被触发。 jquery没有检测到点击子元素
$(".contact").on("click", function() {
alert("clicked");
});
.contacts {
position: absolute;
top: 10px;
left: 300px;
width: 100px;
height: 250px;
border-color: black;
border-style: solid;
z-index: 1;
overflow: scroll;
}
.contact {
position: relative;
width: 80%;
height: 20%;
border-style: solid;
border-color: red;
z-index: 100;
}
<div id="contactList" class="contacts">
<div id="1" class="contact">one</div>
<div id="2" class="contact">two</div>
<div id="3" class="contact">three</div>
</div>
如果我附上父DOM对象一个单击处理程序,它就会被触发。我在这里错过了什么吗?
编辑:
我傻的,我忘了提,孩子们以这种方式添加:
$(".contacts").append($("<div id='"+id+"' class=contact >"+d[contact].name+"</div>"));
其中,“d”和“ID”的变量来自于成功的服务器调用。
这是你的样品http://jsfiddle.net/a6ze1cyo/,它是精细运行,请问是什么问题? – 2014-10-31 19:51:15
所以如果你改变选择器到'$(“。contacts”)。'它有效吗? – dfsq 2014-10-31 19:51:24
@paris你有没有得到任何JS错误? – 2014-10-31 19:52:17