


Solve the problem that the Mouse event of HTML elements is interfered by internal elements_html/css_WEB-ITnose
There is a DIV element with a SPAN element inside it. In order to achieve some special effects, I need to use the onmouseover and onmouseout events of the DIV element. When testing, the following situation will be found:
When the mouse moves inside the DIV, The onmouseover event is triggered; then the mouse moves over the SPAN element inside the DIV. We will definitely not think that the mouse has moved outside the DIV at this time, but the strange thing is that the onmouseout event of the DIV element is triggered, and immediately after the DIV element onmouseover The event was also triggered immediately.
This is not what I want, so how to "shield" the interference of Javascript events caused by inner elements to outer elements?
Here are two methods:
1. setTimeout
Because after the mouse moves over the internal element and the onmouseout event of the outer element is triggered, the onmouseover event of the outer element will also be triggered immediately. , so we only need to delay the action that needs to be performed by the onmouseout event of the outer element for a short period of time, and then execute the clearTimeout method in the onmouseover event, so as to avoid event interference caused by internal elements.Please see the figure below for the specific execution process (the vertical dotted line indicates time):
This is a very clever method, because when onmouseout is triggered, the substantive method is not executed immediately; It takes a little while. If the onmouseover event is triggered immediately again during this period, then it is basically certain that the onmouseout event is triggered due to interference from internal elements, so clearTimeout is used in the onmouseover event to prevent the delayed method execution.
2.contains
Add the following judgment to the method called onmouseover, and then execute the method body when the result is false:if(this.contains(event.fromElement)){return;}
Also in the method called onmouseout Also add the following judgment, and then execute the method body when the result is false:
if(this.contains(event.toElement)){return;}
Let’s explain the meaning of the above two lines of code: In IE, all HTML elements have a contains method, which is used to determine whether the current element contains the specified element. We use this method to determine whether the event of the outer element is triggered because of the internal element. If the internal element causes unnecessary events to be triggered, then we ignore the event.
event.fromElement points to the element the mouse leaves when the onmouseover and onmouseout events are triggered; event.toElement points to the element the mouse enters when the onmouseover and onmouseout events are triggered.
Then the meanings of the above two lines of code are:When the onmouseover event is triggered, determine whether the element the mouse leaves is an internal element of the current element. If so, ignore this event;
When the onmouseout event is triggered When, determine whether the element the mouse enters is an internal element of the current element. If so, ignore this event;
In this way, the internal elements will not interfere with the onmouseover and onmouseout events of the outer element.
But the problem comes again. Non-IE browsers do not support the contains function. However, since we already know the function of the contains function, we can add the following code to add contains support for non-IE browsers. :
if(typeof(HTMLElement) != "undefined"){ HTMLElement.prototype.contains = function(obj) { while(obj != null && typeof(obj.tagName) != "undefind") { if(obj == this) return true; Obj = obj.parentNode; } return false; }; }

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The article discusses the HTML <datalist> element, which enhances forms by providing autocomplete suggestions, improving user experience and reducing errors.Character count: 159

The article discusses the HTML <progress> element, its purpose, styling, and differences from the <meter> element. The main focus is on using <progress> for task completion and <meter> for stati

The article discusses the HTML <meter> element, used for displaying scalar or fractional values within a range, and its common applications in web development. It differentiates <meter> from <progress> and ex

The article discusses the <iframe> tag's purpose in embedding external content into webpages, its common uses, security risks, and alternatives like object tags and APIs.

The article discusses the viewport meta tag, essential for responsive web design on mobile devices. It explains how proper use ensures optimal content scaling and user interaction, while misuse can lead to design and accessibility issues.

The article discusses using HTML5 form validation attributes like required, pattern, min, max, and length limits to validate user input directly in the browser.

Article discusses best practices for ensuring HTML5 cross-browser compatibility, focusing on feature detection, progressive enhancement, and testing methods.

This article explains the HTML5 <time> element for semantic date/time representation. It emphasizes the importance of the datetime attribute for machine readability (ISO 8601 format) alongside human-readable text, boosting accessibilit
