HTML

 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>下拉菜单</title>
<link rel="stylesheet" href="css/style.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script src="js/script.js"></script>
</head>
<body>
<div id="nav">
<ul>
<li><a href="#">首页</a></li>
<li><a href="#">学习 +</a>
<ul>
<li><a href="#">JavaScript</a></li>
<li><a href="#">jQuery</a></li>
</ul>
</li>
<li><a href="#">案例 +</a>
<ul>
<li><a href="#">JavaScript ></a>
<ul>
<li><a href="#">下拉菜单</a></li>
<li><a href="#">图片轮播</a></li>
<li><a href="#">拖拽效果</a></li>
</ul>
</li>
<li><a href="#">jQuery ></a>
<ul>
<li><a href="#">下拉菜单</a></li>
<li><a href="#">图片轮播</a></li>
<li><a href="#">拖拽效果</a></li>
</ul>
</li>
</ul>
</li>
<li><a href="#">关于</a></li>
</ul>
</div>
</body>
</html>

CSS实现三级菜单

 /*静态页面样式*/
* {
margin:;
padding:;
} #nav {
width: 500px;
height: 50px;
margin: 50px auto;
background-color: #ccc;
border-radius: 10px;
} ul li {
list-style: none;
} #nav>ul>li {
float: left;
} ul a {
text-decoration: none;
color: black;
display: block;
text-align: center;
height: 50px;
line-height: 50px;
width: 125px;
background-color: #ccc;
border-radius: 10px;
} ul a:hover {
color: white;
background-color: black;
border-radius: 10px;
} ul ul {
position: absolute;
display: none;
} ul ul ul {
position: absolute;
margin-left: 125px;
margin-top: -50px;
display: none;
} /*CSS显示下拉菜单*/
ul li:hover>ul {
display: block;
}

JS实现三级菜单

 window.onload = showMenu;

 function showMenu() {
var nav = document.getElementById("nav");
var list = nav. getElementsByTagName("li"); for (var i = 0, l = list.length; i < l; i++) {
list[i].onmouseover = function() {
var sub_menu = this.getElementsByTagName("ul")[0];
if(sub_menu) {
sub_menu.style.display = "block";
}
}
list[i].onmouseout = function() {
var sub_menu = this.getElementsByTagName("ul")[0];
if(sub_menu) {
sub_menu.style.display = "none";
}
}
}
}

jQuery实现三级菜单

 $(document).ready(function() {
$("#nav").find("li").mouseover(function() {
$(this).children("ul").show();
});
$("#nav").find("li").mouseout(function() {
$(this).children("ul").hide();
});
})

show()和hide()不能传入参数,传入参数就有bug,原因未知。。。

而且也不支持slide和fade。。。

JS实现动画菜单

 window.onload = showMenu;

 function showMenu() {
var nav = document.getElementById("nav");
var list = nav.getElementsByTagName("li"); for (var i = 0, l = list.length; i < l; i++) {
list[i].onmouseover = function() {
var sub_menu = this.getElementsByTagName("ul")[0];
if(sub_menu) {
sub_menu.style.display = "block";
var addH = function() {
var h = sub_menu.offsetHeight;
h += 5;
if(h >= 100) {
sub_menu.style.height = 100 + "px";
} else {
sub_menu.style.height = h + "px";
}
};
setInterval(addH, 50);
}
} list[i].onmouseout = function() {
var sub_menu = this.getElementsByTagName("ul")[0];
if(sub_menu) {
var subH = function() {
var h = sub_menu.offsetHeight;
h -= 5;
if(h <= 0) {
sub_menu.style.height = 0 + "px";
sub_menu.style.display = "none";
} else {
sub_menu.style.height = h + "px";
}
};
setInterval(subH, 50);
}
}
}
}

可以正常显示菜单,但是无法隐藏菜单。。。

只能显示二级菜单,三级菜单被吃了?!

随着鼠标不停地滑过,显示菜单的速度越来越快。。。

CSS实现动画菜单

 /*静态页面样式*/
* {
margin:;
padding:;
} #nav {
width: 500px;
height: 50px;
margin: 50px auto;
background-color: #ccc;
border-radius: 10px;
box-shadow: 2px 2px 2px rgba(0,0,0,0.8);
} #nav>ul>li>a {
border-radius: 10px;
} #nav ul li {
list-style: none;
} #nav>ul>li {
float: left;
} #nav a {
text-decoration: none;
color: black;
display: block;
height: 50px;
width: 125px;
text-align: center;
line-height: 50px;
background-color: #ccc;
} #nav ul ul {
position: absolute;
/*display: none;*/
opacity:;
margin: 20px 0 0 0;
transition: all 1s ease-in-out;
} #nav ul ul ul {
margin-top: -30px;
margin-left: 160px;
} #nav ul ul a {
border-radius: 10px 10px 0 0;
border-bottom: 1px solid white;
} #nav a:hover {
color: white;
background-color: black;
} #nav>ul>li:hover>ul {
/*display: block;*/
opacity:;
margin: -15px 0 0 0;
} #nav>ul ul>li:hover>ul {
/*display: block;*/
opacity:;
margin-left: 140px;
margin-top: -50px;
} /*CSS画三角形*/
#nav>ul>li>ul>li:first-child:before {
content: "";
display: block;
border-top: 15px solid transparent;
border-right: 15px solid transparent;
border-bottom: 15px solid #ccc;
border-left: 15px solid transparent;
width:;
margin-left: 50px;
} #nav ul ul ul>li:first-child:before {
content: "";
position: absolute;
display: block;
border-top: 15px solid transparent;
border-right: 15px solid #ccc;
border-bottom: 15px solid transparent;
border-left: 15px solid transparent;
width:;
margin-left: -30px;
margin-top: 13px;
}

预先定义的二级菜单和三级菜单的display属性不能设置为none,如果先设置为none然后在鼠标滑过的时候改为block,将完全没有动画效果,原因未知。。。

但是如果display不设置为none,在鼠标滑过菜单(隐形)所在的位置时,也会显示出来,纠结。。。

JS 下拉菜单的更多相关文章

  1. CSS+JS下拉菜单和纯CSS下拉菜单

    下拉菜单 (思路:先把二级定位到屏幕外,鼠标悬停重新定位回来:另一个就是ul浮动,li也浮动) 下拉菜单的一般思路就是把子导航嵌套在无序列表中,把列表定位到屏幕之外,当鼠标悬停在其父列表项上时,重新定 ...

  2. (二)js下拉菜单

    默认的select标签比较难看,UI比较漂亮,如果想要实现UI上的下拉样式,好像必须用js写select,从网上拷贝而且修改了一个下拉框,为了方便以后引用所以记录下来. /* diy_select * ...

  3. css中overflow:hidden的属性 可能会导致js下拉菜单无法显示

    css中overflow:hidden属性导致ExtJS中无法显示下拉滚动条 overflow属性: visible 默认.内容不会被修剪,会呈现在元素之外. hidden 内容会被修剪,但是浏览器不 ...

  4. js下拉菜单默认值为当前年份,下拉菜单的选项为当前年份往前推5年

    1:在jsp或者HTML页面中新建一个下拉框 年度:<select id="cx_nd" name="cx_nd" style="width: ...

  5. JS 下拉菜单案例

    css代码 .nav { width: 300px; height: 400px; list-style: none; padding:; margin: 0 auto; } .nav>li { ...

  6. 原生js下拉菜单

    var oDiv = document.getElementById("sunav"); var oLi = oDiv.getElementsByClassName("s ...

  7. -第2章 JS方法实现下拉菜单显示和隐藏

    知识点 onmouseover 鼠标经过 onmouseout 鼠标移出 function 关键字 getElementsByTagName 获取一组标签 length 获取对象成员个数 思路 给一级 ...

  8. bootstrap的下拉菜单组件与导航条

    前期准备:bootstrap的css文件和js文件先引入 Bootstrap 组件-拉下菜单(class+js) 下拉菜单必需三级结构 <div class="dropdown&quo ...

  9. JS实现带复选框的下拉菜单

    这段时间在做后台的时候需要一个可以复选的下拉菜单,用到的是easyUI中的combo的Demo,先看看官方easyUI:http://www.jeasyui.com/documentation/ind ...

随机推荐

  1. [iOS翻译]《iOS 7 Programming Cookbook》:iOS文件与文件夹管理(下)

    三. 创建文件夹 问题: 你想创建文件夹到磁盘,存储一些文件到里面 解决方案: 使NSFileManager类的实例方法createDirectoryAtPath:withIntermediateDi ...

  2. findstr()与strfind()的区别

    matlab中这两个字符串查找的函数findstr(), strfind()表明上看起来用法相似,效果也相似. 1. findstr(s1,s2)--在较长的字符串中查找较短的字符串出现的次数,并返回 ...

  3. OpenGL、Open Inventor、WebGL、Three.js、ARToolkit、JSARToolkit

    [准备看的] http://www.hewebgl.com/ http://www.linuxdiyf.com/viewarticle.php?id=399205 http://blog.sina.c ...

  4. nodeJs--模块module.exports与实例化方法;

    在nodejs中,提供了exports 和 require 两个对象,其中 exports 是模块公开的接口,require 用于从外部获取一个模块的接口,即所获取模块的 exports 对象.而在e ...

  5. js之数组,对象,类数组对象

    许久不写了,实在是不知道写点什么,正好最近有个同事问了个问题,关于数组,对象和类数组的,仔细说起来都是基础,其实都没什么好讲的,不过看到还是有很多朋友有些迷糊,这里就简单对于定义以及一下相同点,不同点 ...

  6. MATLAB仿真总结

    MATLAB仿真过程中,编写MATLAB代码的时候犯了很多错误,做了很多蠢事.记录下自己犯错的点点滴滴,并引以为戒.使用MATLAB版本为2014a,以下内容如有不当还请指正. 1. 仿真开始前清理工 ...

  7. replace 替换全部的正确姿势

    本文同步自我的个人博客:http://www.52cik.com/2015/11/06/replace-all.html 关于字符串替换问题,其实是个很简单的问题,但却也不那么简单,至少对于很多新手而 ...

  8. [原创]Net实现Excel导入导出到数据库(附源码)

    关于数据库导出到Excel和SQLServer数据导出到Excel的例子,在博客园有很多的例子,自己根据网上搜集资料,自己做了亦歌简单的demo,现在分享出来供初学者学习交流使用. 一.数据库导入导出 ...

  9. Library not found for -lPods 解决方法

    使用cocoapods 经常会遇到的问题. 1. Library not found for -lPods 2. Pods was rejected as an implicit dependency ...

  10. 程序员的出路在哪里?挣钱的机会来了续-福利来了,仿QQ界面,放出全部源码,打造创业框架及实现思路

    上一篇:程序员的出路在哪里?挣钱的机会来了!, 原来搞技术,挣钱,不一定非得要多高精尖,有时候抓住小白用户,解决他们一个很小但是很常用的功能,也是一条很好的出路. 其实很多软件产品,要实现出来没有你想 ...