我有这个jQuery:
$("div.result").live("click", function(event){
alert("kokoko");
});
Run Code Online (Sandbox Code Playgroud)
HTML可能是:
<div id="result">
Flash banner code
Image with link
etc.
</div>
Run Code Online (Sandbox Code Playgroud)
我想要做的是在点击div支架内的任何元素时触发警报.目前,当结果中存在图像横幅时,不会触发警报.
尝试:
$("#result").on("click", function(){
alert("kokoko");
});
// or
$("#result").click(function(){
alert("kokoko");
});
// or just pure JavaScript
document.getElementById("result").addEventListener("click",function(){
alert("kokoko");
});
Run Code Online (Sandbox Code Playgroud)
虽然使用像这样的纯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);
};
}
})();
Run Code Online (Sandbox Code Playgroud)
永远不要使用或推荐不推荐使用的.live() ......
$("#result").on("click", function(event){
alert("kokoko");
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
185 次 |
| 最近记录: |