热门关键字:
jquery > jquery教程 > jquery教程 > jquery实现用ul模拟表单select列表菜单特效

jquery实现用ul模拟表单select列表菜单特效

6840
作者:管理员
发布时间:2012/12/24 19:47:19
评论数:2
转载请自觉注明原文:http://www.jq-school.com/Show.aspx?id=201

文章由【网友small6】提供

现在网站为提高用户体验效果,都采用了美化下拉列表为主,原有的select下拉列表元素样式比较难控制,兼容性比较差,用上了它往往会破坏整体展示效果,为了让下拉列表变成好看,只能用其它方法来代替select了,接下来教大家怎么实现,文章后台带有打包下载和演示例子。

 

第一步:

引入Jquery插件文件如下:

http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js

 

第二步:

样式代码如下:

body {padding:10px;}
* {margin:0; padding:0; font-size:12px;}
ul,li {list-style-type:none;}
.select_box {width:150px; border:1px solid #ccc; padding-right:20px; padding-left:10px; background:url(107.gif) no-repeat 160px center; position:relative;}
.select_box span {cursor:pointer; display:block; line-height:25px; width:100%; height:25px; overflow:hidden;}
.select_box ul li {cursor:pointer;}
.son_ul {width:179px; position:absolute; left:0; top:25px; border:1px dashed #ccc; background:#fff;}
.son_ul li {display:block; line-height:25px; padding-left:10px; width:169px}
.hover {background:#ccc;}

 

第三步:

Jquery代码如下:

$(document).ready(function(){
	$('.son_ul').hide(); //初始ul隐藏
	$('.select_box span').hover(function(){ //鼠标移动函数
		$(this).parent().find('ul.son_ul').slideDown();  //找到ul.son_ul显示
		$(this).parent().find('li').hover(function(){$(this).addClass('hover')},function(){$(this).removeClass('hover')}); //li的hover效果
		$(this).parent().hover(function(){},
			function(){
				$(this).parent().find("ul.son_ul").slideUp(); 
			}
		);
		},function(){}
		);
		$('ul.son_ul li').click(function(){
			$(this).parents('li').find('span').html($(this).html());
			$(this).parents('li').find('ul').slideUp();
		});
	}
);

 

第四步:

html代码如下:

<ul id="main_box">
  <li class="select_box">
    <span>请选择...</span>
    <ul class="son_ul">
      <li>选项一</li>
      <li>选项二</li>
      <li>选项三</li>
      <li>选项四</li>
      <li>选项五</li>
    </ul>
  </li>
</ul>

效果如下:

jquery实现用ul模拟表单select列表菜单特效

 

打包下载

 

在线演示

 

 

 


 





如果您觉得本文的内容对您的学习有所帮助:支付鼓励



关键字:jquery特效 select列表 下拉列表 菜单特效 菜单效果
友荐云推荐