我有一个功能,当鼠标移到屏幕的左侧时,我想从页面的左侧开始显示菜单。以及当鼠标从左侧移开时滑出页面左侧。
问题是因为这个功能总是记录我的鼠标移动,如果鼠标移动了,它会记录它已经超过了点,并不断切换菜单。我需要它只在菜单超过某个X坐标时切换菜单
JS:(编辑代码)
$("#gridcontainer").mousemove(function(e){
var pageCoords = "( " + e.pageX + ", " + e.pageY + " )";
var clientCoords = "( " + e.clientX + ", " + e.clientY + " )";
$("span:first").text("( e.pageX, e.pageY ) : " + pageCoords);
$("span:last").text("( e.clientX, e.clientY ) : " + clientCoords);
var sideMenu = $('.side-menu');
if (e.pageX < 100 && $('.side-menu').is(":visible")){
console.log('make visible');
sideMenu.animate({"left":"-96px"}, 1000);
}
else if(!$('.side-menu').is(":visible")){
sideMenu.animate({"left":"-96px"}, 1000);
console.log('hide');
} });
发布于 2013-03-22 01:55:06
您可以添加一个切换布尔变量,该变量在事件被激活时触发,并在鼠标从该侧移开时更改。然后,只需检查该变量的状态是否为动画。
https://stackoverflow.com/questions/15554652
复制相似问题