我有这个jQuery:
$("div.result").live("click", function(event){
alert("kokoko");
});
HTML可能是:
<div id="result">
Flash banner code
Image with link
etc.
</div>
我想要做的是在单击div holder中的任何元素时触发警报。目前,当结果中有图像横幅时,不会触发警报。
答案 0 :(得分:7)
尝试:
$("#result").on("click", function(){
alert("kokoko");
});
// or
$("#result").click(function(){
alert("kokoko");
});
// or just pure JavaScript
document.getElementById("result").addEventListener("click",function(){
alert("kokoko");
});
虽然使用像这样的纯JavaScript(使用addEvent
和removeEvent
函数)解决跨浏览器问题是一个很好的做法:
(function(){
if ( document.addEventListener ) {
this.addEvent = function(elem, type, fn) {
elem.addEventListener(type, fn, false);
return fn;
};
this.removeEvent = function(elem, type, fn) {
elem.removeEventListener(type, fn, false);
};
} else if ( document.attachEvent ) {
this.addEvent = function(elem, type, fn) {
var bound = function() {
return fn.apply(elem, arguments);
};
elem.attachEvent("on" + type, bound);
return bound;
};
this.removeEvent = function (elem, type, fn) {
elem.detachEvent("on" + type, fn);
};
}
})();
答案 1 :(得分:5)
永远不要使用或推荐不推荐使用的.live() ...
$("#result").on("click", function(event){
alert("kokoko");
});
答案 2 :(得分:1)
这应该这样做:
$("#result").on("click", function(){
alert("it worked!");
});
live已弃用
答案 3 :(得分:1)
应该是div#result .result将是一个类。另外,尽量不要使用live,而是使用.on()。