锁定菜单

锁定菜单

开发工具及关键技术:Visual Studio 2017 Html JQuery
撰写时间:2019-01-28

在这里我给大家分享的功能是锁定菜单,这个功能是由鼠标移入显示移出隐藏事件、锁定后的事件和解锁后的事件
今天我为什么要给大家讲解这个功能呢
因为跟据我浏览的一些服务或者后台网页发现有大多数都有锁定菜单这个功能,
这个功能也是挺实用的
然后这个功能的优点是可以让菜单浮动显示、固定显示、隐藏,
缺点可能就是部分人会觉得麻烦

在这里插入图片描述
(图1)
如(图1)所示,鼠标移入后菜单会显示
(页面打开时,菜单不会自动隐藏,需要鼠标移入再鼠标移出才会隐藏)

在这里插入图片描述
(图2)
如(图2)所示,鼠标移出后菜单会自动隐藏

在这里插入图片描述
(图3)
如(图3)所示,点击锁定菜单按钮后菜单会固定在左侧

在这里插入图片描述
(图4)
如(图4)所示,点击解锁菜单按钮后菜单会自动隐藏

Html代码部分:
在这里插入图片描述
Css代码部分:
在这里插入图片描述

JQuery代码部分:
在这里插入图片描述

OverOut() ;//调用封装好的鼠标移入移出事件
var Lock = true; //声明一个变量lock=true(锁定菜单为true,解锁菜单为false)
$("#Lock").click(function() { //给#Lock添加一个点击事件
	if (Lock == false) { //判断Lock等于false
		Lock = true; //变量Lock等于true
		$(".lock-circle").css("float", "left"); //更改div为左浮动
		$(".lock-circle").css("background", "#585858"); //更改div的背景颜色
		$(this).css("border-color", "#585858"); //更改div的边框颜色
		$(this).css("background", ""); //设置div的背景为空
		$(".lock-text").text("锁定菜单"); //更改div的text值为锁定菜单
		OverOut(); //调用封装好的鼠标移入移出事件
	} else { //Lock不等于false时
		Lock = false; //变量Lock等于false
		$(".lock-circle").css("float", "right"); //更改div为左浮动
		$(".lock-circle").css("background", "#fff"); //更改div的背景颜色
		$(this).css("border-color", "#058de7"); //更改div的边框颜色
		$(this).css("background", "#058de7"); //设置div的背景颜色
		$(".lock-text").text("解锁菜单"); //更改div的text值为锁定菜单
		$("#LeftMenu").off(); //off()函数将会移除#LeftMenu的事件
	}
});

在这里插入图片描述

function OverOut() { //封装鼠标移入移出事件
	$("#LeftMenu").mouseover(function() { //鼠标移入事件
		$("#LeftMenu").css("margin-left", "0px"); //更改#LeftMenu的外边距为0
		$("#main-content").css("width", "calc(100% - 220px)"); //更改#main-content的宽度为100% - 220px 220px是#LeftMenu的宽度
		clearTimeout(mouseOver); //重置间隔函数mouseOver
	});
	$("#LeftMenu").mouseout(function() { //鼠标移出事件
		mouseOver = setTimeout(function() { //设置间隔函数mouseOver,1.5秒后执行
			$("#LeftMenu").css("margin-left", "-217px"); //更改#LeftMenu的外边距为-217px
			$("#main-content").css("width", "calc(100% - 3px)"); //更改#main-content的宽度为100% - 3px 3px是#LeftMenu剩余的宽度可以让鼠标移入显示
		}, 1500);
	});
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值