插件的代码是(我使用这个脚本 - http://www.tanabi.com/js/jquery.imagemap.js):
if(typeof ev.originalTarget.actualPosX == 'undefined'){
jQuery.imagemap.ffGetPosition(ev.originalTarget);
}
我在Firefox上有错误 - ev.originalTarget未定义,在86行
和我的代码:
jQuery.fn.imagecoords = function() {
return this.each(function(){
jQuery(this).click(function(ev){
//var coords;
var x = jQuery.imagemap.getEventX(ev);
var y = jQuery.imagemap.getEventY(ev);
jQuery('#x').val(x+4);
jQuery('#y').val(y+2);
jQuery('#new_point').remove();
jQuery('#map').append('<a href="javascript:void(0)" id="new_point" class="bullet" rel="' + x + '-' + y + '" style="left: ' + x + 'px; top: ' + y + 'px; display: block; "> </a>');
return 0;
});
});
};
答案 0 :(得分:1)
您可以使用jQuery的event.target
。
http://api.jquery.com/category/events/event-object/#event.target
答案 1 :(得分:1)
你的问题是jQuery正在处理你的不是实际的事件对象,而是一些jQuery包装器对象围绕着真实的东西。你可能想要ev.originalEvent.originalTarget
。
答案 2 :(得分:0)
在访问ev.originalTarget.something之前,您需要检查是否已定义ev.originalTarget。
if(ev.originalTarget) {
if(typeof ev.originalTarget.actualPosX == 'undefined') {
jQuery.imagemap.ffGetPosition(ev.originalTarget);
}
}
else {
// Handle undefined or null originalTarget
}
您也可以使用
if (typeof(ev.originalTarget) != 'undefined' && ev.originalTarget != null)
而不是
if(ev.originalTarget)
但是如果(ev.originalTarget)会更快。