JS-事件之鼠标、键盘都能控制的下拉选框效果

<script type="text/javascript">
window.onload=function(e){
    var box=document.getElementById(‘divselect‘),
        title=box.getElementsByTagName(‘cite‘)[0],
        menu=box.getElementsByTagName(‘ul‘)[0],
        as=box.getElementsByTagName(‘a‘),//as是一个集合
        index=-1;

    // 点击三角时
    title.onclick=function(event){
        event = event || window.event;
        if(event.stopPropagation){
            event.stopPropagation();
        }else{
            event.cancelBubble = true;
        };//以上是阻止冒泡的判断语句
        menu.style.display = "block";

      //添加键盘事件
      //问题出在按了回车之后,怎么把对应的分类内容填进去。
      document.onkeyup = function(event){
        event = event || window.event;
//        console.log(event.keyCode)//用这个方法获取到:回车是13,空格是32,上键是38,下键是40;
        /***********
        if(event.keyCode===32){
            alert(‘kg‘);
        }else if(event.keyCode===13){
            //看来必须要是三个等号才会成立。
            alert(‘hc‘);
        }
        ********/
        if(event.keyCode===40){
            index++;
            if(index > as.length-1){
                index = 0
            };
            for(var i=0;i<as.length;i++){
                as[i].style.backgroundColor = null;
            };
            as[index].style.backgroundColor = "#ccc";
        };
        if(event.keyCode===38){
            index--;
            if(index<0){
                index = as.length-1;
            }
            for(var i=0;i<as.length;i++){
                as[i].style.backgroundColor = null;
            };
            as[index].style.backgroundColor = "#ccc";
        }
        if(event.keyCode===13){
            for(var i=0;i<as.length;i++){
                as[i].style.backgroundColor = null;
            };
            title.innerHTML = as[index].innerHTML;
                   menu.style.display = "none";
        }
     };
  };
       //封装-命名函数
// var overColor = function(){
//         this.style.backgroundColor = "#ccc";
// }
//    function outColor(){
//         this.style.backgroundColor = null;
//     }
//    function replaceInner(){
//         title.innerHTML = this.innerHTML;
//         menu.style.display = "none";
//     }
   // 滑过滑过、离开、点击每个选项时
   for(var i=0;i<as.length;i++){
//     as[i].onmouseover = overColor;
//     as[i].onmouseout = outColor;
//     as[i].onclick = replaceInner;
//写法2——直接调用
    as[i].onmouseover = function(){
           this.style.backgroundColor = "#ccc";
           };
       as[i].onmouseout = function(){
           this.style.backgroundColor = null;
           };
       as[i].onclick = function(){
           title.innerHTML = this.innerHTML;
           menu.style.display = "none";
           };
    };//当实在找不到错误的时候,看看是不是不小心删掉了花括号啥的
   // 点击页面空白处时
   document.addEventListener(‘click‘,function(){
       //注意区分:attachEvent(ie中添加事件监听器的方法)和addEventListener(通用浏览器中添加事件监听器)。别搞混了写成attachEventListener了!!
       menu.style.display = "none";
   },false);

}
   </script>

<div id="divselect">
      <cite>请选择分类</cite>
      <ul>
         <li id="li"><a href="javascript:;" selectid="1">ASP开发</a></li>
         <li><a href="javascript:;" selectid="2">.NET开发</a></li>
         <li><a href="javascript:;" selectid="3">PHP开发</a></li>
         <li><a href="javascript:;" selectid="4">Javascript开发</a></li>
         <li><a href="javascript:;" selectid="5">Java特效</a></li>
      </ul>
    </div>

html

<style type="text/css">
body,ul,li{ margin:0; padding:0; font-size:13px;}
ul,li{list-style:none;}
#divselect{width:186px; margin:80px auto; position:relative; z-index:10000;}
#divselect cite{width:150px; height:24px;line-height:24px; display:block; color:#807a62; cursor:pointer;font-style:normal;
padding-left:4px; padding-right:30px; border:1px solid #333333;
background:url(xjt.png) no-repeat right center;}
#divselect ul{width:184px;border:1px solid #333333; background-color:#ffffff; position:absolute; z-index:20000; margin-top:-1px; display:none;}
#divselect ul li{height:24px; line-height:24px;}
#divselect ul li a{display:block; height:24px; color:#333333; text-decoration:none; padding-left:10px; padding-right:10px;}
    </style>

任务
一、 点击菜单中的向下三角展开菜单
提示:
1、点击三角时需阻止事件冒泡
二、 展开菜单之后,在document对象上绑定keyup事件,(键盘事件不是某个具体的对象了,所以要帮到document上面来)按下向下方向键,选中下一个选项,按下向上方向键,选中上一个选项,按下回车键菜单收起,显示选中项
提示:
1、 声明一个全局的index变量初值为-1
2、 按下向下方向键时index递增,当递增至大于等于菜单选项的总数时恢复为0
3、 按下向上方向键时判断index,如若小于等于0则设为菜单选项的总数,之后递减index
4、 根据index值将对应的选项设为当前(灰色背景)
5、 按下回车键时将对应选中的选项设为菜单标题,且将所有选项设为无背景,index恢复为-1,菜单收起
注意:没有任何选项被选中时,按下回车键不做任何操作
三、鼠标滑过每个选项时高亮显示,离开时去掉背景,点击高亮选项时菜单标题改变
提示:
1.遍历所有a标签,绑定鼠标点击的事件
注意:要考虑到浏览器兼容,使用innerHTML,不要使用innerText
四、点击页面空白处收起菜单
提示:
1.绑定在document对象上

慕课练习题:http://www.imooc.com/code/3631

时间: 2024-07-29 17:55:51

JS-事件之鼠标、键盘都能控制的下拉选框效果的相关文章

vmware+centos7+启动在登录界面鼠标键盘都不可用

vmware workstation12 + centos7启动后登录界面和单任务运行鼠标键盘都不可用 所有操作都是在root用户下进行的 因为安装别的软件,安装了kernel-headers和kernel-devel,在网上 直接下载安装的,所以比原先新,用uname -r命令查看kernel版本, 然后发现不一致,就卸载kernel-headers和kernel-devel, 在光盘中安装 和kernel版本对应的,kernel-headers卸载不掉,有其余更高版本的依 赖项,只能升级ke

[js开源组件开发]模拟下拉选项框select

模拟下拉选项框select 在css3流行的情况下,下拉框还是无法满足PD的需求,所以有了autosearch,有了模拟下拉框.效果如下图: select DEMO请案例点击这里查看.http://www.lovewebgames.com/jsmodule/select.html 源码查看下载请点击这里https://github.com/tianxiangbing/select 调用示例 <select name="select" id="select"&g

可控制导航下拉方向的jQuery下拉菜单代码

效果:http://hovertree.com/texiao/nav/1/ 代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>可控制导航下拉方向的jQuery下拉菜单代码 - 何问起</title> <base ta

JS+CSS打造仿QQ面板的三级折叠下拉菜单

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>JS+CSS打造仿QQ面板的三级折叠下拉菜单-石家庄地毯</title> <style type="text/css"> *{ margin:0px; padding:0px; border:0p

jquery.chosen.js下拉选择框美化插件项目实例

由于之前使用的bootstrap-select插件是建立在bootstrap基础上的,实际使用到项目中的时候,与我们使用的ace-admin(基于bootstrap)存在样式冲突,导致下拉框的样式发生变化.为了界面的美观,不得已查资料寻找另外的插件. 使用jquery.chosen.js下拉选择框美化插件同样也能达到类似效果 完成效果如下 实现步骤如下 1.导入相关文件 <link rel="stylesheet" href="${ctxStatic}/css/chos

js下拉选项框

功能实现:在js下拉选项框中不能出现属于自己的选项 在js文件中首先运行function函数 var dep = ["自己的选项","别人的选项"] 在function函数中动态的为#other下拉选项框添加option选项 $(function(){  var roomid = $("#roomId").val(); //所属部门 将部门名字添加到html页面 //通过#roomOwnerDeptId的值获取html中的自己的选项值 var s

JavaScript onkeydown事件入门实例(键盘某个按键被按下)

JavaScript onkeydown 事件 用户按下一个键盘按键时会触发 onkeydown 事件.与 onkeypress事件不同的是,onkeydown 事件是响应任意键按下的处理(包括功能键),onkeypress 事件只响应字符键按下后的处理. 提示 Internet Explorer/Chrome 浏览器使用 event.keyCode 取回被按下的字符,而 Netscape/Firefox/Opera 等浏览器使用 event.which. onkeydown 获取用户按下的键

1.鼠标点击换样式+2.下拉菜单缓慢显示/隐藏样式效果

1.鼠标点击换样式 <style type="text/css"> .aa{ width:90px; height:60px;text-align:center; vertical-align:middle; line-height:60px; margin-right:10px; font-size:19px; float:left; background-color:#06F} </style> <body> <div style=&quo

微信小程序的按下抬起事件,下拉选择框的事件及点击确定的方法函数,获取时间的方法,省市区的方法。

抬起按下的事件: 抬起事件: bind:touchstart="nanOne"   把这条属性放到标签里就可以了 在JS中 nanOne: function () { this.setData({ nvimg: '../img/nvOne.png', }) }, 按下事件: bind:touchend="nanTwo" 把这条属性放到标签里就可以了 在JS中 nanTwo: function () { this.setData({ nvimg: '../img/nv