PHP程序员站--PHP编程开发平台
 当前位置:主页 >> 网页制作 >> Javascript >> 

使用CSS和jQuery制作漂亮的下拉选项菜单

使用CSS和jQuery制作漂亮的下拉选项菜单

来源:PHP程序员站  作者:PHP程序员站  发布时间:2011-06-06
我们在进行表单设计时,可能要用到select下拉选项控件,遗憾的是,IE浏览器默认的select控件外观非常丑陋,而且不能用样式来控制,不能在选项中添加图片等信息。今天我将通过实例来讲解如何用CSS和jQuery来制作漂亮的下拉选项菜单。 XHTML div id = dropdown p 请选择

我们在进行表单设计时,可能要用到select下拉选项控件,遗憾的是,IE浏览器默认的select控件外观非常丑陋,而且不能用样式来控制,不能在选项中添加图片等信息。今天我将通过实例来讲解如何用CSS和jQuery来制作漂亮的下拉选项菜单。

 

XHTML

<div id="dropdown"> 
    <p>请选择城市</p> 
    <ul> 
        <li><a href="#">长沙</a></li> 
        <li><a href="#">北京</a></li> 
        <li><a href="#">南京</a></li> 
        <li><a href="#">堪培拉</a></li> 
        <li><a href="#">多伦多</a></li> 


    </ul> 
</div> 

可以看出,我们使用div来替换下拉选项控件原生的select标签。

CSS

#dropdown{width:186pxmargin:80px autoposition:relative
#dropdown p{width:150pxheight:24pxline-height:24pxpadding-left:4pxpadding-right:30px;  
border:1px solid #a9c9e2background:#e8f5fe url(arrow.gif) no-repeat right 4px;  
color:#807a62cursor:pointer

#dropdown ul{width:184pxbackground:#e8f5femargin-top:2pxborder:1px solid #a9c9e2;  
position:absolutedisplay:none
#dropdown ul li{height:24pxline-height:24pxtext-indent:10px
#dropdown ul li a{display:blockheight:24pxcolor:#807a62text-decoration:none

#dropdown ul li a:hover{background:#c6dbfccolor:#369

样式不要多讲,你可以修改CSS中的背景色和字体颜色,甚至其他任意定义的样式。有一个下拉箭头的小图标,已经打包在附件里了。

jQuery

首先,当单击“请选择城市”时,判断下拉的层“ul”是否处于显示状态,如果是则隐藏下拉选项,否则则打开(下滑)下拉选项。

$("#dropdown p").click(function(){ 
    var ul = $("#dropdown ul"); 
    if(ul.css("display")=="none"){ 
        ul.slideDown("fast"); 


    }else{ 
        ul.slideUp("fast"); 
    } 
}); 

然后,当单击下拉选项时,获取选项内容,将选项内容写入到<p>标签中,同时隐藏下拉选项。

$("#dropdown ul li a").click(function(){ 
    var txt = $(this).text(); 
    $("#dropdown p").html(txt); 
    $("#dropdown ul").hide(); 
}); 

这样就完成了一个简单的下拉选项的操作,是不是很简单啊。

当然,如果与后台交互,需要获取选项的value值,那就需要先定义XHTML。

<div id="dropdown"> 
    <p>请选择城市</p> 
    <ul> 
        <li><a href="#" rel="1">长沙</a></li> 

        <li><a href="#" rel="2">北京</a></li> 
        <li><a href="#" rel="3">南京</a></li> 


        <li><a href="#" rel="4">堪培拉</a></li> 
        <li><a href="#" rel="5">多伦多</a></li> 
    </ul> 
</div> 
<div id="result"></div> 

从代码中可以看出,在给a标签加个rel属性,并赋值,就相当于select的option标签的value值。接下来就是通过jQuery获取rel值,请看代码:

$("#dropdown ul li a").click(function(){ 
    var txt = $(this).text(); 
    $("#dropdown p").html(txt); 
    var value = $(this).attr("rel"); 
    $("#dropdown ul").hide(); 
    $("#result").html("您选择了"+txt+",值为:"+value); 
}); 

这样就完成了一个完整的下拉选项的操作。


延伸阅读:
很眩的半透明下拉菜单导航条
用DIV+js模拟的一个下拉菜单(select)源码
用DIV+js模拟的一个下拉菜单(select)
25个优秀的下拉菜单导航脚本
用CSS3制作网页下拉菜单代码
jQuery+CSS实现多级下拉菜单
30 款下拉菜单导航菜单脚本欣赏
jQuery水平下拉菜单插件 jdMenu
Tags: css   jQuery   下拉选项   下拉菜单  
最新文章
推荐阅读
月点击排行榜
PHP程序员站 Copyright © 2007-2010,PHPERZ.COM All Rights Reserved 粤ICP备07503606号