首页 > 语言 > JavaScript > 正文

jQuery结合CSS制作漂亮的select下拉菜单

2024-05-06 16:19:11
字体:
来源:转载
供稿:网友

对于我来说,标准的HTML元素(Select)已经让我感到讨厌。它不能够正常的在IE浏览器上显示。还有一点就是他并不仅仅包含简单的文本。本实例将完全摒弃select元素,通过JQuery和CSS来构建DropDown元素。

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

XHTML

 

 
  1. <div id="dropdown">  
  2. <p>请选择城市</p>  
  3. <ul>  
  4. <li><a href="#">长沙</a></li>  
  5. <li><a href="#">北京</a></li>  
  6. <li><a href="#">南京</a></li>  
  7. <li><a href="#">堪培拉</a></li>  
  8. <li><a href="#">多伦多</a></li>  
  9. </ul>  
  10. </div>  

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

CSS

 

 
  1. #dropdown{width:186pxmargin:80px autoposition:relative}  
  2. #dropdown p{width:150pxheight:24pxline-height:24pxpadding-left:4pxpadding-right:30px;  
  3. border:1px solid #a9c9e2background:#e8f5fe url(arrow.gif) no-repeat right 4px;  
  4. color:#807a62cursor:pointer}  
  5. #dropdown ul{width:184pxbackground:#e8f5femargin-top:2pxborder:1px solid #a9c9e2;  
  6. position:absolutedisplay:none}  
  7. #dropdown ul li{height:24pxline-height:24pxtext-indent:10px}  
  8. #dropdown ul li a{display:blockheight:24pxcolor:#807a62text-decoration:none}  
  9. #dropdown ul li a:hover{background:#c6dbfccolor:#369}  

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

jQuery

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

 

 
  1. $("#dropdown p").click(function(){  
  2. var ul = $("#dropdown ul");  
  3. if(ul.css("display")=="none"){  
  4. ul.slideDown("fast");  
  5. }else{  
  6. ul.slideUp("fast");  
  7. }  
  8. });  

然后,当单击下拉选项时,获取选项内容,将选项内容写入到

标签中,同时隐藏下拉选项。

 

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

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

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

 

 
  1. <div id="dropdown">  
  2. <p>请选择城市</p>  
  3. <ul>  
  4. <li><a href="#" rel="1">长沙</a></li>  
  5. <li><a href="#" rel="2">北京</a></li>  
  6. <li><a href="#" rel="3">南京</a></li>  
  7. <li><a href="#" rel="4">堪培拉</a></li>  
  8. <li><a href="#" rel="5">多伦多</a></li>  
  9. </ul>  
  10. </div>  
  11. <div id="result"></div> 

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

 

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

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

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选