获取relatedTarget属性
在做mouseenter与mouseleave的兼容时,我们需要用到事件对象的relatedTarget属性
function getRelatedTarget(e) {
var t = e.relatedTarget
if (t) {
return t
}
return e.fromElement === e.target ?
e.toElement :
e.fromElement;
}
String("mouseenter,mouseleave").replace(/\w+/g, function (type) {
eventHooks[type] = function (dom) {
var eventType = type === "mouseenter" ? "mouseover" : "mouseout";
addEvent(dom, eventType, function (e) {
var t = getRelatedTarget(e)
if (!t || (t !== dom && !dom.contains(t))) {
dispatchEvent(e, type, true);
}
});
};
});本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!