<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=shift_jis" />
<title>jquery</title>
<style type="text/css">
ul{
float:left
}
li{
list-style-type:none;
}
ul ul li{
}
</style>
<script src="jquery-1.4.3.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function(){
$("ul li").next("ul").hide();
$("ul li").mouseover(function()
{
$(this).next("ul").slideDown();
});
$("ul ul").mouseleave(function()
{
$(this).slideUp();
});
$('ul ul li').mouseover(function(){
$(this).css('background-color','red');
});
$('ul ul li').mouseout(function(){
$(this).css('background-color','white');
});
})
</script>
</head>
<body>
<ul >
<li>one</li>
<ul >
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
</ul>
<ul >
<li>two</li>
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
</ul>
<ul >
<li>three</li>
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
</ul>
</body>
</html>
上面是一个下拉菜单效果的源码,效果图如下:
提出如下问题:
1.为什么要用$(document).ready()事件?
--不用不行,呵呵。
当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。
这是事件模块中最重要的一个函数,因为它可以极大地提高web应用程序的响应速度。
简单地说,这个方法纯粹是对向window.load事件注册事件的替代方法。通过使用这个方法,可以在DOM载入就绪能够读取并操纵时立即调用你所绑定的函数,而99.99%的JavaScript函数都需要在那一刻执行。
2.$("ul ul").mouseleave()改成mouseout为啥不行?
--
大家知道事件的冒泡特性,在上面的BUG中也正是因为这个冒泡特性,对于mouseover事件来说 ,当鼠标从其他元素 移动到 child节点时发生,但此事件会冒泡 所以会导致 parent 也出发mouseover。如果我们对 parent注册了 mouseover监听,从 parent移动到child 同样出发parent的mouseover 有时候我们不希望这样的事情发生。
对于 mouseover 和mouseenter 两个事件 最大的区别就是 mouseenter 是 不冒泡的事件,这时候 如果注册的监听 是mouseenter的话 无论鼠标从任何元素 移动到child时 只有child元素 发生mouseenter事件 而其祖宗节点 都不会因为冒泡 而触发此事件。
3.你能让1、2、3与one对齐吗?
改成如下排列,以li为单位
<ul>
<li><a href="#">AAAAA</a>
<ul >
<li><a href="#">11</a></li>
<li><a href="#">22</a></li>
<li><a href="#">33</a></li>
<li><a href="#">44</a></li>
</ul>
</li>
</ul>
下面是相对强大点的实例
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script src="js/jquery-1.5.1.min.js"></script>
<script type="text/javascript">
$(function(){
$('.meun').hover(function(){
$(this).find('ul').stop(true,true).slideDown();
},function(){$(this).find('ul').stop(true,true).slideUp('fast');
})
})
</script>
<style>
*{margin:0;padding:0;}
a{text-decoration:none;color:#333;font-size:14px;}
ul{list-style:none;}
.nav{display:inline-block;margin:20px;height:30px;line-height:30px;background:#eee;}
.meun {float:left;position:relative;}
.meun a{display:inline-block;padding:0 10px;}
.meun a:hover{background:#333;}
.meun a:hover{color:#fff;}
.meun ul{display:none;position:absolute;left:0;top:30px;width:100px;background:#eee;border:1px solid #d3d3d3}
.meun ul a{display:block;}
</style>
</head>
<body>
<div class="nav">
<ul>
<li class="meun in1"><a href="#">AAAAA</a>
<ul id="sub_01" class="sub" >
<li><a href="#">11</a></li>
<li><a href="#">22</a></li>
<li><a href="#">33</a></li>
<li><a href="#">44</a></li>
</ul>
</li>
<li class="meun in2"><a href="#">BBBBB</a>
<ul id="sub_01" class="sub" >
<li><a href="#">11</a></li>
<li><a href="#">22</a></li>
<li><a href="#">33</a></li>
<li><a href="#">44</a></li>
</ul>
</li>
<li class="meun in1"><a href="#">CCCCC</a>
<ul id="sub_01" class="sub" >
<li><a href="#">11</a></li>
<li><a href="#">22</a></li>
<li><a href="#">33</a></li>
<li><a href="#">44</a></li>
</ul>
</li>
</ul>
</div>
</body></html>
我觉得这个可移植性很好,比较清晰。。。。