In JavaScript, the execution sequence of mousedown, mouseup, and click is left to right. More importantly, once the mousedown event is activated, normal situation (the method not bound in the mousedown event uses a similar alert method, because the pop-up object box prevents event transmission, that is, the subsequent call event is lost) the next two events will certainly be activated. We usually bind only one click event to a tag. In fact, events such as mousedown and mouseup are also called to trigger the click event, but their call cycle is very short, in addition, we didn't write the relevant functions to bind these two events, so we won't be aware of them. Now, if you want to register these events on a tag and bind the specified handler, you will encounter the following problems in actual development.
First, I will test it through a simple example and discover the problem I mentioned, so that you can have an intuitive impression, and then I will look at my solution.
Copy codeThe Code is as follows:
<Div id = "div1" onmousedown = "mouseDownFun ();" onmouseup = "mouseUpFun ();" onclick = "clickFun ();" style = "background: # CCC; border: 3px solid #999; width: 200px; height: 200px; padding: 10px "> </div>
<Input style = "margin-top: 10px" type = "button" onclick = "document. getElementById ('div1 '). innerHTML = '';" value = "clear information"/>
<Script type = "text/javascript">
Function mouseDownFun ()
{
Document. getElementById ('div1 '). innerHTML + = 'mousedown <br/> ';
}
Function mouseUpFun ()
{
Document. getElementById ('div1 '). innerHTML + = 'mouseup <br/> ';
}
Function clickFun ()
{
Document. getElementById ('div1 '). innerHTML + = 'click <br/> ';
}
</Script>
Now let us assume that we have the following requirement: Press mousedown on an image to start dragging the image, and when the mouseup mouse is released on the image, the relevant information of the image is displayed. Under normal circumstances, if you want to run the function bound to mouseup, the function bound to mousedown is executed first, that is, when you view the image information, the image is also being dragged. In fact, what you really want is to execute one of the methods each time. For example, when you press the mouse and release it quickly, you actually want to see the image information, instead of dragging the image, if you press the mouse and pause, it indicates that you want to drag the image. In this case, do not run the information display method. How can this be done? According to the above analysis, I found that the setTimeout function can be used to deal with this requirement (of course, if you find a better solution, remember to share it with me ). The following is a complete example, which is very simple. It is also annotated with no additional explanation:
Copy codeThe Code is as follows:
<Div id = "div1" onmousedown = "mouseDownFun ();" onmouseup = "mouseUpFun ();" style = "background: # CCC; border: 3px solid #999; width: 200px; height: 200px; padding: 10px "> </div>
<Input style = "margin-top: 10px" type = "button" onclick = "document. getElementById ('div1 '). innerHTML = '';" value = "clear information"/>
<Script type = "text/javascript">
Var doMouseDownTimmer = null;
Var isMouseDownDoing = false;
Function mouseDownFun ()
{
// This variable is reinitialized here because mouseDownFun calls it every time.
IsMouseDownDoing = false;
// The onmousedown real processing code is called after a delay of 200 milliseconds. If the mouse is released within 200 milliseconds and the doMouseDownTimmer is cleared, onmousedown is called even if it is called, actually, the doMouseDown function is not called as the code to be processed by onmousedown.
DoMouseDownTimmer = setTimeout (doMouseDown, 200 );
}
Function doMouseDown ()
{
// If this method is called 200 milliseconds later, set isMouseDownDoing to true, indicating that the actual processing of mouseDown occurs, and then the mouseUp will not be processed.
IsMouseDownDoing = true;
Document. getElementById ('div1 '). innerHTML + = 'mousedown <br/> ';
}
Function mouseUpFun ()
{
If (! IsMouseDownDoing)
{
ClearTimeout (doMouseDownTimmer); // you can enter here to clear doMouseDownTimmer no matter how many milliseconds it takes. Otherwise, the doMouseDown method will be called after 200 milliseconds.
Document. getElementById ('div1 '). innerHTML + = 'mouseup <br/> ';
}
}
</Script>
Related topic: Because the commonly used click events run after mousedown and mouseup, we can use mouseup instead of click (this is used in the above example ), at this time, do not register the click event on the Element. Of course, if you can, you can also directly use mousedown instead of click, and the event response will be faster. Some Google Products see such a method, such as Gmail.