js模拟select下拉菜单控件的代码


Posted in Javascript onMay 08, 2013
<!DOCTYPE html>
 <html>
 <head>
 <script src="http://code.jquery.com/jquery-1.7.2.min.js"></script>
 <meta charset=utf-8 />
 <title>js模拟select</title>
 </head>
    <style>
   *{ margin:0; padding:0;}
   li{ list-style:none;}
   body{ font:12px "宋体"; color:#666;}
   .select_down{ margin:100px auto; position:relative; width:600px; min-height:200px; height:auto!important; height:200px; border:1px solid #ccc; padding:20px; border-radius: 8px}
   .select_down dt{float:left;width:134px;position:relative;margin-right:5px;display:inline;}
   .select_down h3{color: #919191; font-size:12px;font-weight: normal;border:1px solid #e5e5e5;height:18px;background:#fbfbfb;line-height: 18px;text-indent:8px;}
   .select_down ul{width: 132px;border: 1px solid #e5e5e5;background:#fbfbfb;position: absolute;top: 18px;left: 0;
 z-index: 1;text-indent:8px;display:none;}
 .select_down ul li{height:22px;line-height: 22px;cursor:pointer;}
 .select_down ul li.hover{background:#f2f2f2;}
  .select_down dt a{background:url('https://3water.com/hxh-hua/478335/o_select.jpg') no-repeat;position:absolute;width:18px;height:18px;top:1px;right:1px; }
   </style>
 <body>
   <div class="select_down" id="sel">
           <dl>
             <dt>
                 <h3>select选择</h3>
                 <a href="javascript:;"></a>
                 <ul>
                     <li>jq的select模拟1</li>
                     <li>jq的select模拟2</li>
                     <li>jq的select模拟3</li>
                 </ul>
             </dt>
             <dt>
                 <h3>select选择2</h3>
                 <a href="javascript:;"></a>
                 <ul>
                     <li>jq的select模拟11</li>
                     <li>jq的select模拟22</li>
                     <li>jq的select模拟31</li>
                 </ul>
             </dt>         </dl>
 </div>
   <script>
     window.onload=function(){
     var oflink = document.getElementById('sel');
     var aDt = oflink.getElementsByTagName('dt');
     var aUl = oflink.getElementsByTagName('ul');
     var aH3= oflink.getElementsByTagName('h3');
     for(var i=0;i<aDt.length;i++){
         aDt[i].index = i;
         aDt[i].onclick = function(ev){
             var ev = ev || window.event;
             var This = this;
             for(var i=0;i<aUl.length;i++){
                 aUl[i].style.display = 'none';
             }
             aUl[this.index].style.display = 'block';
             document.onclick = function(){
                 aUl[This.index].style.display = 'none';
             };
             ev.cancelBubble = true;
         };
     }
     for(var i=0;i<aUl.length;i++){
         aUl[i].index = i;
         (function(ul){
             var iLi = ul.getElementsByTagName('li');
             for(var i=0;i<iLi.length;i++){
                 iLi[i].onmouseover = function(){
                     this.className = 'hover';
                 };
                 iLi[i].onmouseout = function(){
                     this.className = '';
                 };
                 iLi[i].onclick = function(ev){
                     var ev = ev || window.event;
                     aH3[this.parentNode.index].innerHTML = this.innerHTML;
                     ev.cancelBubble = true;
                     this.parentNode.style.display = 'none';
                 };
             }
         })(aUl[i]);
     }
 }
   </script>
 </body>
 </html>
Javascript 相关文章推荐
Javascript操作cookie的函数代码
Oct 03 Javascript
jQuery插件windowScroll实现单屏滚动特效
Jul 14 Javascript
Jquery操作cookie记住用户名
Mar 29 Javascript
js仿淘宝和百度文库的评分功能
May 15 Javascript
jqueryUI tab标签页代码分享
Oct 09 jQuery
Vue中v-for的数据分组实例
Mar 07 Javascript
vue父组件异步获取数据传给子组件的方法
Jul 26 Javascript
JavaScript数组、json对象、eval()函数用法实例分析
Feb 21 Javascript
js实现中文实时时钟
Jan 15 Javascript
小程序实现背景音乐播放和暂停
Jun 19 Javascript
js前端传json后台接收‘‘被转为quot的问题解决
Nov 12 Javascript
Vue + iView实现Excel上传功能的完整代码
Jun 22 Vue.js
js工具方法弹出蒙版
May 08 #Javascript
基于JavaScript 声明全局变量的三种方式详解
May 07 #Javascript
你必须知道的JavaScript 变量命名规则详解
May 07 #Javascript
你必须知道的JavaScript 中字符串连接的性能的一些问题
May 07 #Javascript
基于JavaScript实现继承机制之构造函数方法对象冒充的使用详解
May 07 #Javascript
基于JavaScript实现继承机制之调用call()与apply()的方法详解
May 07 #Javascript
JS中的substring和substr函数的区别说明
May 07 #Javascript
You might like
php自定义函数call_user_func和call_user_func_array详解
2011/07/14 PHP
浅谈PHP调用Webservice思路及源码分享
2014/06/04 PHP
浅谈thinkphp的实例化模型
2015/01/04 PHP
showModalDialog 和 showModelessDialog
2007/01/22 Javascript
javascript与CSS复习(《精通javascript》)
2010/06/29 Javascript
JavaScript 浏览器验证代码(来自discuz)
2010/07/17 Javascript
ajax处理php返回json数据的实例代码
2013/01/24 Javascript
使用jquery.validate自定义方法实现&quot;手机号码或者固话至少填写一个&quot;的逻辑验证
2014/09/01 Javascript
JS设置cookie、读取cookie、删除cookie
2015/04/17 Javascript
javascript禁止访客复制网页内容的实现代码
2015/08/05 Javascript
jquery+css3实现会动的小圆圈效果
2016/01/27 Javascript
node.js 中国天气预报 简单实现
2016/06/06 Javascript
移动端 一个简单易懂的弹出框
2016/07/06 Javascript
JS简单去除数组中重复项的方法
2016/09/13 Javascript
jquery对象和DOM对象的相互转换详解
2016/10/18 Javascript
浅谈使用splice函数对数组中的元素进行删除时的注意事项
2016/12/04 Javascript
jQuery实现的无缝广告图片左右滚动功能详解
2016/12/24 Javascript
Bootstrap的popover(弹出框)在append后弹不出(失效)
2017/02/27 Javascript
jquery.form.js异步提交表单详解
2017/04/25 jQuery
vue中将网页打印成pdf实例代码
2017/06/15 Javascript
Grunt针对静态文件的压缩,版本控制打包的实例讲解
2017/09/29 Javascript
微信小程序实现上传图片功能
2018/05/28 Javascript
jquery实现动态创建form并提交的方法示例
2019/05/27 jQuery
基于Vue和Element-Ui搭建项目的方法
2019/09/06 Javascript
JavaScrip如果基于url实现图片下载
2020/07/03 Javascript
vue大型项目之分模块运行/打包的实现
2020/09/21 Javascript
[01:05:30]VP vs TNC 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
Python实现的爬取小说爬虫功能示例
2019/03/30 Python
Python3基于plotly模块保存图片表格
2020/08/03 Python
CSS3属性 line-clamp控制文本行数的使用
2020/03/19 HTML / CSS
免费获得微软MCSD证书赶快行动吧!
2012/11/13 HTML / CSS
不拖欠农民工工资承诺书
2014/03/31 职场文书
放飞中国梦演讲稿
2014/04/23 职场文书
穷人该怎么创业?谨记以下几点
2019/07/11 职场文书
golang生成vcf通讯录格式文件详情
2022/03/25 Golang
在 Python 中利用 Pool 进行多线程
2022/04/24 Python