DIV菜单层实现代码


Posted in Javascript onNovember 19, 2010

他便给我截了个图是,QQ商城的分类菜单,效果如下:
DIV菜单层实现代码
我看了一下,咦!咱们这博客园也是这种呀!我自己之前也没做过这种效果,正好自己试试!(我不是做美工的,不过到js略懂罢了!)
一、分析:
1,右边大分类肯定是一个层下面用divMenuContent表示
2,左边鼠标移上去的那个应该也是个层,下面用divMenuItem表示
问题:怎么样表现过如图的样子呢?左边和右边看起来是一体的!于是想到divMenuItem的右边为none,而且z轴高于divMenuContent,让它正好压在divMenuContent的边框上!
下面是两个层的样式:

#divMenuItem 
{ 
position:absolute; 
z-index:99; 
width:147px; 
height:25px; 
border:3px solid #963; 
border-right:0px; 
background-color:#FC9; 
display:none; 
} 
#divMenuContent 
{ 
display:none; 
position:absolute; 
z-index:98; 
width:200px; 
height:505px; 
border:3px solid #963; 
background-color:#FC9; 
}

然后布局一个页面测试用:
<body> 
<br /> 
<br /> 
<br /> 
<ul class="menu" id="menu"> 
<li>aaaaaaaaaaaaa</li> 
<li>bbbbbbbbbbbbb</li> 
<li>cccccccdccccc</li> 
<li>ddddddddddddd</li> 
<li>eeeeeeeeeeeee</li> 
<li>fffffffffffff</li> 
<li>ggggggggggggg</li> 
<li>hhhhhhhhhhhhh</li> 
</ul> 
<div id="divMenuItem"></div> 
<div id="divMenuContent"></div> 
</body>

简单设置一下menu的样式:
body 
{ 
margin:0px; 
padding:0px; 
} 
.menu 
{ 
list-style-type:none; 
float:left; 
border:1px solid green; 
width:150px; 
} 
.menu li 
{ 
height:25px; 
background-color:#CCC; 
border:1px solid red; 
}

主要实现:
$("#menu li").mouseenter(function() 
{ 
var offset=$(this).offset(); 
$("#divMenuItem") 
.offset({ 
top:offset.top,left:offset.left 
}) 
.html($(this).html()) 
.show() 
$("#divMenuContent") 
.offset({ 
top:offset.top,left:offset.left+$(this).width()-1 
}) 
.show() 
})

这里主要就是定位问题了!逻辑上是对的,可发现除一次移上去显示正常外,以后每移上的第一个都有点错位!这里也是一直没搞明白是怎么回事!后来在show()后又offset()了一下就好了,希望高人指明。
修改后的全部JS如下:
$(function(){ 
$("#divMenuItem,#divMenuContent").mouseout(function(e) 
{ 
if($(e.toElement).parent().attr("id")!="menu" && $(e.toElement).attr("id")!="divMenuContent") 
{ 
$("#divMenuItem").hide(); 
$("#divMenuContent").hide(); 
} 
}) 
$("#menu li").mouseenter(function() 
{ 
var offset=$(this).offset(); 
$("#divMenuItem") 
.offset({ 
top:offset.top,left:offset.left 
}) 
.html($(this).html()) 
.show() 
.offset({ 
top:offset.top,left:offset.left 
}); 
$("#divMenuContent") 
.offset({ 
top:offset.top,left:offset.left+$(this).width()-1 
}) 
.show() 
/* .offset({ 
top:offset.top,left:offset.left+$(this).width()-1 
});*/ 
.offset({ 
top:$("#menu li").first().offset().top,left:offset.left+$(this).width()-1 
}); 
}) 
})

里面有一块注释,offset()那块,它和下面的offset()是两个效果,现在的效果图:

DIV菜单层实现代码

 

注释部分换一下效果图:

DIV菜单层实现代码

 

效果已在:IE6,7,8,chrome中测试通过!
代码打包下载/201011/yuanma/menu_jquery1.rar

Javascript 相关文章推荐
Div自动滚动到末尾的代码
Oct 26 Javascript
CSS+Table图文混排中实现文本自适应图片宽度(超简单+跨所有浏览器)
Feb 14 Javascript
JavaScript中的正则表达式简明总结
Apr 04 Javascript
基于jQuery实现网页打印功能
Dec 01 Javascript
AngularJs学习第五篇从Controller控制器谈谈$scope作用域
Jun 08 Javascript
微信小程序 页面跳转及数据传递详解
Mar 14 Javascript
JavaScript设计模式之代理模式详解
Jun 09 Javascript
vue2+el-menu实现路由跳转及当前项的设置方法实例
Nov 07 Javascript
JavaScript函数绑定用法实例分析
Nov 14 Javascript
Vue入门之数据绑定(小结)
Jan 08 Javascript
微信小程序实现订单倒计时
Nov 01 Javascript
vue与django集成打包的实现方法
Nov 11 Javascript
jQuery 定时局部刷新(setInterval)
Nov 19 #Javascript
基于jquery的跨域调用文件
Nov 19 #Javascript
jquery.cvtooltip.js 基于jquery的气泡提示插件
Nov 19 #Javascript
jQuery lazyload 的重复加载错误以及修复方法
Nov 19 #Javascript
JQuery 选择和过滤方法代码总结
Nov 19 #Javascript
基于jquery的一个OutlookBar类,动态创建导航条
Nov 19 #Javascript
非阻塞动态加载javascript广告实现代码
Nov 17 #Javascript
You might like
收音机发烧友应当熟知的100条知识
2021/03/02 无线电
一个php作的文本留言本的例子(四)
2006/10/09 PHP
PHP学习笔记之三 数据库基本操作
2011/01/17 PHP
深入浅出php socket编程
2015/05/13 PHP
PHP实现文件上传和多文件上传
2015/12/24 PHP
Thinkphp开发--集成极光推送
2017/09/15 PHP
PHP实现的分解质因数操作示例
2018/08/01 PHP
JavaScript flash复制库类 Zero Clipboard
2011/01/17 Javascript
VBS通过WMI监视注册表变动的代码
2011/10/27 Javascript
jquery ajax例子返回值详解
2012/09/11 Javascript
JavaScript中使用Object.prototype.toString判断是否为数组
2015/04/01 Javascript
JavaScript实现Iterator模式实例分析
2015/06/09 Javascript
JavaScript三种绑定事件方式及相互之间的区别分析
2017/01/10 Javascript
JavaScript 详解预编译原理
2017/01/22 Javascript
angular使用bootstrap方法手动启动的实例代码
2017/07/18 Javascript
说说node中的可读流和可写流的区别
2018/06/01 Javascript
jQuery实现经典的网页3D轮播图封装功能【附源码下载】
2019/02/15 jQuery
vue组件之间的数据传递方法详解
2019/04/19 Javascript
微信小程序 行的删除和增加操作实现详解
2019/09/29 Javascript
[04:16]DOTA2英雄梦之声_第09期_斧王
2014/06/21 DOTA
python使用cookielib库示例分享
2014/03/03 Python
在Python的Bottle框架中使用微信API的示例
2015/04/23 Python
Python注释详解
2016/06/01 Python
python和mysql交互操作实例详解【基于pymysql库】
2019/06/04 Python
python中时间、日期、时间戳的转换的实现方法
2019/07/06 Python
django如何自己创建一个中间件
2019/07/24 Python
Python 安装 virturalenv 虚拟环境的教程详解
2020/02/21 Python
关于Python错误重试方法总结
2021/01/03 Python
HTML5中的音频和视频媒体播放元素小结
2016/01/29 HTML / CSS
俄罗斯金苹果网上化妆品和香水商店:Goldapple
2019/12/01 全球购物
夜大毕业自我鉴定
2013/10/11 职场文书
简历的自荐信
2013/12/19 职场文书
工程造价专业大学生职业生涯规划书
2014/01/18 职场文书
音乐器材管理制度
2014/01/31 职场文书
如何签定毕业生就业协议书
2014/09/28 职场文书
教师个人工作总结范文2014
2014/11/10 职场文书