js下拉菜单,怎样更简便的实现?

JavaScript026

js下拉菜单,怎样更简便的实现?,第1张

你这个效果的下拉菜单,不需要用 JavaScript,只用CSS就能实现。

加上一句

li:hover ul{ display:block}

就行了。

<!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/htmlcharset=utf-8"/>

<title>无标题文档</title>

<style type="text/css">* {

margin: 0px

padding: 0px

}

body {

font-family: Verdana, Geneva, sans-serif

font-size: 14px

}

#nav {

width: 600px

height: 40px

background-color: #eee

margin: 0 auto

}

ul {

list-style: none

}

ul li {

float: left

line-height: 40px

text-align: center

width: 100px

}

a {

text-decoration: none

color: #000

display: block

}

a:hover {

color: #F00

background-color: #666

}

ul li ul li {

float: none

background-color: #eee

margin: 2px 0px

}

ul li ul {

display: none

}

li:hover ul{ display:block}

</style>

</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="#">Html/CSS</a></li>

</ul>

</li>

<li><a href="#">学习中心</a>

<ul>

<li><a href="#">视频学习</a></li>

<li><a href="#">实例练习</a></li>

<li><a href="#">问与答</a></li>

</ul>

</li>

<li><a href="#">经典案例</a></li>

<li><a href="#">关于我们</a></li>

</ul>

</div>

</body>

</html>

下拉菜单关键在于HTML的布局和CSS的样式写法。这有这两个写好了后,js操作起来才非常的简单。下面是简单例子,仅供参考:

<html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN">

<head><meta http-equiv="Content-Type" content="text/html charset=gb2312" />

<title>js菜单演示_怎么使用js_js下拉菜单_简单js下拉菜单_怎么做js下拉菜单</title>

<style type="text/css">

    *{margin:0padding:0border:0}

    body {font-family: arial, 宋体, seriffont-size:12px}

    #nav {line-height: 24px list-style-type: none background:#666}

    #nav a {display: block width: 80px text-align:center}

    #nav a:link {color:#666 text-decoration:none}

    #nav a:visited {color:#666text-decoration:none}

    #nav a:hover {color:#FFFtext-decoration:nonefont-weight:bold}

    #nav li {float: left width: 80px background:#CCC}

    #nav li a:hover{background:#999}

    #nav li ul {line-height: 27px list-style-type: nonetext-align:leftleft: -999em width: 180px position: absolute}

    #nav li ul li{float: left width: 120pxbackground: #F6F6F6}

    #nav li ul a{display: block width: 100pxtext-align:leftpadding-left:20px}

    #nav li ul a:link {color:#666 text-decoration:none}

    #nav li ul a:visited {color:#666text-decoration:none}

    #nav li ul a:hover {color:#F3F3F3text-decoration:nonefont-weight:normalbackground:#C00}

    #nav li:hover ul {left: auto}

    #nav li.onhover ul {left: auto}

    #content {clear: left}

</style>

<script type="text/javascript">

function menu() {

    var oLi = document.getElementById("nav").getElementsByTagName("li")

    for (var i=0 i<oLi.length i++) {

    oLi[i].onmouseover=function() {

        this.className+=(this.className.length>0? " ": "") + "onhover"

    }

    oLi[i].onMouseDown=function() {

        this.className+=(this.className.length>0? " ": "") + "onhover"

    }

    oLi[i].onMouseUp=function() {

        this.className+=(this.className.length>0? " ": "") + "onhover"

    }

    oLi[i].onmouseout=function() {

        this.className=this.className.replace(new RegExp("( ?|^)onhover\b"),""  )}}}

window.onload=menu

</script></head>

<body>

<ul id="nav">

<li><a href="http://jingyan.baidu.com/article/fc07f98917a56f12ffe5198a.html" target="_blank" >动漫之家</a>

<ul>

<li>

<a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉一</a></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉二</a></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉三</a></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉四</a></li>

</ul></li><li><a href="http://jingyan.baidu.com/article/e73e26c0cfa01724adb6a795.html" target="_blank" >js详解</a><ul>

<li><a href="http://jingyan.baidu.com/article/e73e26c0cfa01724adb6a795.html"  target="_blank" >下拉一</a></li>

<li><a href="http://jingyan.baidu.com/article/e73e26c0cfa01724adb6a795.html" target="_blank"  >下拉二</a></li>

<li><a href="http://jingyan.baidu.com/article/e73e26c0cfa01724adb6a795.html" target="_blank"  >下拉三</a></li>

<li><a href="http://jingyan.baidu.com/article/e73e26c0cfa01724adb6a795.html" target="_blank"  >下拉四</a></li></ul></li>

<li><a href="http://jingyan.baidu.com/article/08b6a591f09cfc14a8092293.html" target="_blank" >js运用</a>

<ul><li><a href="http://jingyan.baidu.com/article/08b6a591f09cfc14a8092293.html"  target="_blank" >下拉一</a></li>

<li><a href="http://jingyan.baidu.com/article/08b6a591f09cfc14a8092293.html"  target="_blank" >下拉二</a></li>

<li><a href="http://jingyan.baidu.com/article/08b6a591f09cfc14a8092293.html"  target="_blank" >下拉三</a></li>

<li><a href="http://jingyan.baidu.com/article/08b6a591f09cfc14a8092293.html" target="_blank"  >下拉四</a></li></ul></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >关于我们</a>

<ul><li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html" target="_blank"  >下拉一</a></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉二</a></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉三</a></li>

<li><a href="http://jingyan.baidu.com/article/363872ecedf4486e4ba16f92.html"  target="_blank" >下拉四</a></li>

</ul></li><li><a href="http://jingyan.baidu.com/article/cdddd41c5e873153cb00e193.html"  target="_blank" >js在线演示</a>

<ul><li><a href="http://jingyan.baidu.com/article/cdddd41c5e873153cb00e193.html"  target="_blank" >下拉一</a></li>

<li><a href="http://jingyan.baidu.com/article/cdddd41c5e873153cb00e193.html"  target="_blank" >下拉二</a></li>

<li><a href="http://jingyan.baidu.com/article/cdddd41c5e873153cb00e193.html"  target="_blank" >下拉三</a></li>

<li><a href="http://jingyan.baidu.com/article/cdddd41c5e873153cb00e193.html"  target="_blank" >下拉四</a></li></ul></li>

<li><a href="http://jingyan.baidu.com/article/76a7e409bb3c33fc3b6e1593.html"  target="_blank" >联系我们</a>

<ul><li><a href="http://jingyan.baidu.com/article/76a7e409bb3c33fc3b6e1593.html"  target="_blank" >下拉一</a></li>

<li><a href="http://jingyan.baidu.com/article/76a7e409bb3c33fc3b6e1593.html"  target="_blank" >下拉二</a></li>

<li><a href="http://jingyan.baidu.com/article/76a7e409bb3c33fc3b6e1593.html"  target="_blank" >下拉三</a></li>

<li><a href="http://jingyan.baidu.com/article/76a7e409bb3c33fc3b6e1593.html"  target="_blank" >下拉四</a></li></li></ul>

</body>

</html>

思路:

如果下拉菜单是options 。

你可以使用for循环,创建options,然后添加text ,value和一些属性。最后放到select标签里。

如果你是用其他标签模拟的下拉菜单。和上面的方法是一样的,只是你要自己写样式。