Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Prevent middle mouse click scrolling

I'm looking for a way to stop the middle mouse click from causing the browser to start scrolling, and showing the little scroll 'compass'.

I have seen Disabling middle click scrolling with javascript however the solution is a bit more hackey than I would like, and doesn't seem like something I could actually use.

I'm looking for a more definitive "This is how you do it" or "You cannot do that, son".

I am of course open to hacks and workarounds.

Just because S.O. questions look nicer with code, here is what I am using to close tooltips when right or middle clicking.

msg.mousedown(function(e) {
    if (e.which == 2) {   //middle mouse click
        msg.hide();
        e.preventScrolling();   //if only this worked...
    }
    else if (e.which == 3) {   //right mouse click
        msg.hide();
    }
}).bind('contextmenu', function(e) {
    e.preventDefault();
}).click(function(e) {
    e.stopPropagation();
});

edit: jQuery, JavaScript, whatever, let's just all play nicely now :)

Edit 2:

I'm more interested in preventing the little scroll 'compass' than stopping the page from scrolling. I guess that wasn't very clear from my initial description.

like image 391
elwyn Avatar asked Feb 27 '11 23:02

elwyn


People also ask

How do I turn off the middle mouse click?

If the middle mouse switch has an open spring, carefully bend the spring so it presses up against the wheel a bit harder. Alternatively, push a bit of springy closed-cell plastic foam between the switch and wheel so as to increase the force needed to depress the switch.

How do I stop my mouse from scrolling in Chrome?

go to chrome://flags/#scrollable. to enable scrolling, set to defaults: "Tab Scrolling" and "Tab Scrolling Buttons" to disable scrolling, enable: "Tab Scrolling" and "Tab Scrolling Buttons" Restart chrome/chromium.

What is middle click scroll called?

"auto-scroll", "Auto-scrolling is a feature that can be found in most mainstream modern applications. Pressing the middle mouse button transfers the application into the auto-scrolling mode.


2 Answers

Use:

$('body').mousedown(function(e){if(e.button==1)return false}); 

This works on Chrome: http://jsfiddle.net/PKpBN/3/

like image 62
pimvdb Avatar answered Oct 04 '22 16:10

pimvdb


There's no need to include jQuery just for this.

If you are using jQuery, there are already some great answers here. If not, you can use vanilla JS:

document.body.onmousedown = function(e) { if (e.button === 1) return false; }
like image 41
rnevius Avatar answered Oct 04 '22 16:10

rnevius