jQuery实现仿京东防抖动菜单效果示例
程序员文章站
2022-06-08 20:32:17
本文实例讲述了jquery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下:
完整代码:
本文实例讲述了jquery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下:
完整代码:
<!doctype html> <html> <head> <title>www.jb51.net jquery仿京东菜单</title> <meta charset="utf-8"> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <style type="text/css"> *{ padding: 0; margin: 0; } li{ list-style: none; } a{ color:#555; } .menu{ width: 220px; border: 2px solid #333; position: relative; } .menu_item{ height: 47px; padding-left:20px; line-height: 47px; background-color:#feebf3; border-bottom: 1px solid #f0bfd3; } .menu_item.current{ background-color: #fff; } .menu_cont{ position: absolute; width: 500px; height: 150px; top: 0; left: 220px; padding: 15px; border: 1px solid #666; } </style> </head> <body> <h2>防抖动</h2> <div class="menu"> <ul class="menu_list"> <li class="menu_item"><a href="">热点要闻</a></li> <li class="menu_item"><a href="">个性推荐</a></li> <li class="menu_item"><a href="">北京新闻</a></li> <li class="menu_item"><a href="">环球视野</a></li> </ul> <div class="menu_cont" style="display:none"> <div class="menu_cont_list"> <ul> <li> <h3><a href="">618,刘强东笑了,很多人哭了</a></h3> </li> <li> <h3><a href="">普通人如何分享人民币增值红利</a></h3> </li> <li> <h3><a href="">大都市里藏板房小学闷热无比 </a></h3> </li> </ul> </div> <div class="menu_cont_list"> <ul> <li> <h3><a href="">中国炼油产能过剩超亿吨 油价迫近4元降回到十年前</a></h3> </li> <li> <h3><a href="">银行大幅上调首套房贷利率 这些人最受影响</a></h3> </li> <li> <h3><a href="">江南大范围强降雨再次来袭 今明北方旱区多雷阵雨</a></h3> </li> </ul> </div> <div class="menu_cont_list"> <ul> <li> <h3><a href="">京郊特产组团进超市 类似活动将在全市推开</a></h3> </li> <li> <h3><a href="">北京某高档小区地下二层防空洞改群租房</a></h3> </li> <li> <h3><a href="">北京市民踊跃收听收看市党代会开幕直播</a></h3> </li> </ul> </div> <div class="menu_cont_list"> <ul> <li> <h3><a href="">英国推出“钱味香水”:随时感受钞票味儿</a></h3> </li> <li> <h3><a href="">美国是如何买下阿拉斯加的?为何俄国悔不当初?</a></h3> </li> <li> <h3><a href="">将增近4000人,美国为何欲大幅增兵阿富汗?</a></h3> </li> </ul> </div> </div> </div> <script type="text/javascript"> $(document).ready(function(){ var $menu = $(".menu"); var $menuitem = $(".menu_item"); var $menucont = $(".menu_cont"); var $menucontlist= $(".menu_cont_list") var menutimer; $menuitem.on("mouseenter", function(){ var self = $(this); menutimer = settimeout(function(){ self.addclass("current"); self.siblings().removeclass("current"); $menucont.show(); var _index = self.index(); $menucontlist.eq(_index).show(); $menucontlist.eq(_index).siblings().hide(); },500) }).on("mouseleave", function(){ if(menutimer){ cleartimeout(menutimer); } }) $menu.on("mouseleave", function(){ $menucont.hide(); }) }) </script> </body> </html>
使用本站html/css/js在线运行测试工具:http://tools.jb51.net/code/htmljsrun,可得到如下测试运行效果:
问题:鼠标第一次移入的时候是不需要延迟的,所以加入了mouseflag
优化后的js为
$(function(){ var _cattimer; var _mouseflag; var $menu = $("#menu"); var $menuitem = $menu.find(".menu_list").children("li");//菜单 var $menucont = $menu.find(".menu_cont");//容器 var $menucontitem = $menucont.children("div");// $menucont.hide();//默认隐藏容器窗口 $menuitem.on("mouseenter", function(){ var self = $(this); if(!_mouseflag){ showcont(self); _mouseflag = true; }else{ _cattimer = settimeout(function(){ showcont(self) },300) } }).on("mouseleave", function(){ if(_cattimer){ cleartimeout(_cattimer); } }) $menu.on("mouseleave",function(){ $menucont.hide(); $menuitem.removeclass("current"); }) var showcont = function (self) { self.addclass("current"); self.siblings().removeclass("current"); $menucont.show();//显示容器窗口 var _index = self.index();//获取位置 $menucontitem.eq(_index).show(); $menucontitem.eq(_index).siblings().hide(); } })
更多关于jquery相关内容感兴趣的读者可查看本站专题:《jquery切换特效与技巧总结》、《jquery扩展技巧总结》、《jquery常用插件及用法总结》、《jquery拖拽特效与技巧总结》、《jquery常见经典特效汇总》、《jquery动画与特效用法总结》及《jquery选择器用法总结》
希望本文所述对大家jquery程序设计有所帮助。