美文网首页
练习:键盘移动DIV

练习:键盘移动DIV

作者: 虎三呀 | 来源:发表于2018-02-08 14:30 被阅读0次
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            #box1{
                width: 100px;
                height: 100px;
                background-color: red;
                position: absolute;
            }
            
            
        </style>
        
        <script type="text/javascript">
            
            //使div可以根据不同的方向键向不同的方向移动
            /*
             * 按左键,div向左移
             * 按右键,div向右移
             * 。。。
             */
            window.onload = function(){
                
                    
                //定义一个变量,来表示移动的速度
                var speed = 10;
                
                //创建一个变量表示方向
                //通过修改dir来影响移动的方向
                var dir = 0;
                
                //开启一个定时器,来控制div的移动
                setInterval(function(){
                    /*
                     * 37 左
                     * 38 上
                     * 39 右
                     * 40 下
                     */
                    switch(dir){
                        case 37:
                            //alert("向左"); left值减小
                            box1.style.left = box1.offsetLeft - speed + "px";
                            break;
                        case 39:
                            //alert("向右");
                            box1.style.left = box1.offsetLeft + speed + "px";
                            break;
                        case 38:
                            //alert("向上");
                            box1.style.top = box1.offsetTop - speed + "px";
                            break;
                        case 40:
                            //alert("向下");
                            box1.style.top = box1.offsetTop + speed + "px";
                            break;
                    }
                },30);
                
                
                
                //为document绑定一个按键按下的事件
                document.onkeydown = function(event){
                    event = event || window.event;
                    
                    //当用户按了ctrl以后,速度加快
                    if(event.ctrlKey){
                        speed = 500;
                    }else{
                        speed = 10;
                    }
                    
                    //使dir等于按键的值
                    dir = event.keyCode;
                };
                
                //当按键松开时,div不再移动
                document.onkeyup = function(){
                    //设置方向为0
                    dir = 0;
                };
                
            };
            
            
        </script>
    </head>
    <body>
        <div id="box1"></div>
    </body>
</html>

相关文章

  • 练习:键盘移动DIV

  • 键盘事件

    发送留言 键盘控制div移动

  • 键盘 控制div 移动

  • JS移动、旋转div

    实现效果 JS叠加、移动、旋转div 实现方式对比 1、添加div2、通过rotate插件实现旋转3、通过键盘监听...

  • JS键盘事件 长按停顿问题

    问题描述:用js的键盘事件控制一个div移动,当按下一个方向键不放,div会先停顿一下,然后才开始持续移动。(原因...

  • 键盘停顿问题

    问题描述:用js的键盘事件控制一个div移动,当按下一个方向键不放,div会先停顿一下,然后才开始持续移动。(原因...

  • JS键盘事件长按时的停顿问题

    问题描述:用js的键盘事件控制一个div移动,当按下一个方向键不放,div会先停顿一下,然后才开始持续移动。(原因...

  • JS用键盘控制DIV移动

    键盘控制DIV移动需要用到onkeydown事件,当然也需要知道按键的键值keyCode,这样才能起效果。另外需要...

  • 前端面试题之CSS

    题目:如下图,当鼠标移动到右边的div时,左边的div变为红色;当鼠标移动到左边的div时,右边的div变为红色。...

  • div模拟键盘

    输入编号 123456789 关闭回删 //点击DIV输入框 var input_txt=document.que...

网友评论

      本文标题:练习:键盘移动DIV

      本文链接:https://www.haomeiwen.com/subject/qyjttftx.html