解决思路如下:
首先,判断事件的当前节点,也就是jquery的currenttarget是否在target的包含中,即下面的扩展$.containsnode。
然后,在调用hover的时候的mouver和mouseout事件里判断currenttarget是否在target的包含中,即$.fn.fhover扩展
下面就是相关代码:
代码如下:
$.containsnode = function(parentnode, childnode) {
if (parentnode.contains) {
return parentnode != childnode && parentnode.contains(childnode);
} else {
return !!(parentnode.comparedocumentposition(childnode) & 16);
}
}
$.fn.fhover = function(over, out) {
this.hover(function(e) {
if ($.containsnode(e.target, e.currenttarget)) {
return;
}
over.call(this, e);
}, function(e) {
if ($.containsnode(e.target, e.currenttarget)) {
return;
}
out.call(this, e);
});
return this;
}
如对本文有疑问, 点击进行留言回复!!
JavaScript 好题汇总分享(持续更新,看到好题就写)
XMLHttpRequest 2级 &&进度事件&&JSONP
使用递归原生实现拷贝&&最简单的方法实现深拷贝
网友评论