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


Posted in Javascript onMay 03, 2015

我们在进行表单设计时,可能要用到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:186px; margin:80px auto; position:relative} 
#dropdown p{width:150px; height:24px; line-height:24px; padding-left:4px; padding-right:30px; 
border:1px solid #a9c9e2; background:#e8f5fe url(arrow.gif) no-repeat right 4px; 
color:#807a62; cursor:pointer} 
#dropdown ul{width:184px; background:#e8f5fe; margin-top:2px; border:1px solid #a9c9e2; 
position:absolute; display:none} 
#dropdown ul li{height:24px; line-height:24px; text-indent:10px} 
#dropdown ul li a{display:block; height:24px; color:#807a62; text-decoration:none} 
#dropdown ul li a:hover{background:#c6dbfc; color:#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); 
});

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

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

Javascript 相关文章推荐
js中如何把字符串转化为对象、数组示例代码
Jul 17 Javascript
js将字符串转成正则表达式的实现方法
Nov 13 Javascript
JS中的log对象获取以及debug的写法介绍
Mar 03 Javascript
js 动态为textbox添加下拉框数据源的方法
Apr 24 Javascript
JS实现的4种数字千位符格式化方法分享
Mar 02 Javascript
Javascript函数式编程简单介绍
Oct 11 Javascript
js css+html实现简单的日历
Jul 14 Javascript
Bootstrap企业网站实战项目4
Oct 14 Javascript
Angular实现下拉框模糊查询功能示例
Jan 03 Javascript
vue cli使用融云实现聊天功能的实例代码
Apr 19 Javascript
原生javascript单例模式的应用实例分析
Feb 23 Javascript
vue.js中使用微信扫一扫解决invalid signature问题(完美解决)
Apr 11 Javascript
jQuery实现的向下图文信息滚动效果
May 03 #Javascript
JQuery插件Quicksand实现超炫的动画洗牌效果
May 03 #Javascript
JQuery页面地址处理插件jqURL详解
May 03 #Javascript
jQuery的animate函数实现图文切换动画效果
May 03 #Javascript
php+ajax+jquery实现点击加载更多内容
May 03 #Javascript
jquery插件hiAlert实现网页对话框美化
May 03 #Javascript
javascript结合canvas实现图片旋转效果
May 03 #Javascript
You might like
PHP 执行系统外部命令 system() exec() passthru()
2009/08/11 PHP
使用cookie实现统计访问者登陆次数
2013/06/08 PHP
thinkphp在模型中自动完成session赋值示例代码
2014/09/09 PHP
PHP的Yii框架中移除组件所绑定的行为的方法
2016/03/18 PHP
Javascript的一种模块模式
2008/03/22 Javascript
BOM与DOM的区别分析
2010/10/26 Javascript
基于Jquery实现的一个图片滚动切换
2012/06/21 Javascript
javascript在myeclipse中报错的解决方法
2013/10/29 Javascript
输入框过滤非数字的js代码
2014/09/18 Javascript
浅谈EasyUI中Treegrid节点的删除
2015/03/01 Javascript
使用jQuery或者原生js实现鼠标滚动加载页面新数据
2016/03/06 Javascript
Vuejs第十篇之vuejs父子组件通信
2016/09/06 Javascript
vue 运用mock数据的示例代码
2017/11/07 Javascript
js和jQuery以及easyui实现对下拉框的指定赋值方法
2018/01/23 jQuery
JS禁用右键、禁用Ctrl+u、禁用Ctrl+s、禁用F12的实现代码
2020/12/01 Javascript
[02:50]【扭转乾坤,只此一招】DOTA2永雾林渊版本开启新篇章
2020/12/22 DOTA
Python sys.path详细介绍
2013/10/17 Python
Python中生成器和yield语句的用法详解
2015/04/17 Python
使用Python生成url短链接的方法
2015/05/04 Python
对Python中gensim库word2vec的使用详解
2018/05/08 Python
解决win64 Python下安装PIL出错问题(图解)
2018/09/03 Python
Django保护敏感信息的方法示例
2019/05/09 Python
Python线程条件变量Condition原理解析
2020/01/20 Python
Tensorflow训练MNIST手写数字识别模型
2020/02/13 Python
python selenium xpath定位操作
2020/09/01 Python
Django扫码抽奖平台的配置过程详解
2021/01/14 Python
HTML5 语义化结构化规范化
2008/10/17 HTML / CSS
美国知名运动产品零售商:Foot Locker
2016/07/23 全球购物
英国鞋类及配饰零售商:Kurt Geiger
2017/02/04 全球购物
什么是SQL Server的确定性函数和不确定性函数
2016/08/04 面试题
食堂员工工作职责
2013/12/18 职场文书
中国文明网向国旗敬礼活动精彩寄语2014
2014/09/27 职场文书
2015年网管个人工作总结
2015/05/22 职场文书
2015年见习期个人工作总结
2015/05/28 职场文书
公安忠诚教育心得体会
2016/01/23 职场文书
使用python求解迷宫问题的三种实现方法
2022/03/17 Python