在此页面上:http://www.colorz.fr/#!/work/
您可以看到图像滚动进出鼠标进入和离开的方向。这是怎么做到的?
答案 0 :(得分:5)
当mouseleave
事件触发元素时,您可以获取光标的x / y坐标:
$('#my-element').on('mouseleave', function (event) {
//check to see what quadrant of the element the mouse has left the element
//you could get a lot more complex than this but here's an example to get you going
if (event.offsetX > 50 && event.offsetY > 50) {
alert('bottom-right');
} else if (event.offsetX > 50 && event.offsetY <= 50) {
alert('top-right');
} else if (event.offsetX <= 50 && event.offsetY <= 50) {
alert('top-left');
} else {
alert('bottom-left');
}
});
答案 1 :(得分:0)
由于mouseout
事件和screenX
/ screenY
/ clientX
/ clientY
属性,可以使用简单的三角法计算方向。< / p>
答案 2 :(得分:0)
它只响应垂直和水平方向。如果您尝试对角线图片,它不起作用。
因此,基于此,我认为您可以使用mousemove
事件为您提供x和y位移。如果x displace大于y,则表示用户正在水平移动,反之亦然。