I have noticed that in Chrome (I'm using Chrome 35.0.1916.114 [UPDATE: also occurs in "35.0.1916.153 m"], Windows 7 64-bit) when I click the left button not only is a mouseDown event raised (as I expect) but also a mouseMove.
In this fiddle if you click in the input element you will see a 'D' for each mouseDown event raised and an 'M' for each mouseMove.
HTML:
<input id="txt" type="text"/>
<p>Moves</p><p id="moves">0</p>
<p>Downs</p><p id="downs">0</p>
<p id="activity">Activity</p>
JS:
$( "#txt" ).mousedown(function() {
document.getElementById("activity").innerHTML +="D";
update(false,true);
});
$( "#txt" ).mousemove(function() {
document.getElementById("activity").innerHTML +="M";
update(true,false);
});
function update(move, down)
{
var moves=document.getElementById("moves").innerHTML;
if (move)
{
moves ++;
document.getElementById("moves").innerHTML=moves;
}
var downs=document.getElementById("downs").innerHTML;
if (down)
{
downs ++;
document.getElementById("downs").innerHTML=downs;
}
var d=parseInt(downs);
var m=parseInt(moves);
if ((d+m)%25==0)
{
document.getElementById("activity").innerHTML +="<br>";
}
}
In FF and IE11 once the cursor is in the input element then you will be able to get consecutive 'D's (ie, a click raises a single mouseDown event). In Chrome each mouse click raises a mouseDown and two mouseMove events.
This is not due to any slight wobbling of the mouse as I use a trackball so the cursor is absolutely stationary.
Is anyone aware of a workaround for this?
Thanks Dave
Note: This differs from the click event in that click is fired after a full click action occurs; that is, the mouse button is pressed and released while the pointer remains inside the same element. mousedown is fired the moment the button is initially pressed.
MouseDown occurs when the user presses the mouse button; MouseUp occurs when the user releases the mouse button.
That means that if you stop the propagation for the onmousemove event when you start dragging, it will never bubble up to the document node and in turn will result in the draggable div never being dragged untill you actually move the mouse outside the "inner" div area.
The ng-mousedown directive tells AngularJS what to do when a mouse button is clicked on the specific HTML element. The ng-mousedown directive from AngularJS will not override the element's original onmousedown event, both will be executed.
strange issue indeed, however with a little flag this can be circumvented: http://jsfiddle.net/3a28p7ek/
the change is pretty straight forward, setting ignoreNextMove
to true
on each mouse down and canceling the move handler if this flag is set, after resetting the flag so that regular move events get handled properly:
ignoreNextMove = false;
$( "#txt" ).mousedown(function() {
ignoreNextMove = true;
document.getElementById("activity").innerHTML +="D";
update(false,true);
});
$( "#txt" ).mousemove(function() {
if(ignoreNextMove)
{
ignoreNextMove = false;
return;
}
document.getElementById("activity").innerHTML +="M";
update(true,false);
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With