js实现上下左右键盘控制div移动


Posted in Javascript onJanuary 16, 2020

本文实例为大家分享了js上下左右键盘控制div移动的具体代码,供大家参考,具体内容如下

描述:

div通过键盘事件上下左右实现div块的移动

效果: 

js实现上下左右键盘控制div移动

实现:

js:

var Method=(function () {
  return {
    EVENT_ID:"event_id",
    loadImage:function (arr) {
      var img=new Image();
      img.arr=arr;
      img.list=[];
      img.num=0;
//      如果DOM对象下的事件侦听没有被删除掉,将会常驻堆中
//      一旦触发了这个事件需要的条件,就会继续执行事件函数
      img.addEventListener("load",this.loadHandler);
      img.self=this;
      img.src=arr[img.num];
    },
    loadHandler:function (e) {
      this.list.push(this.cloneNode(false));
      this.num++;
      if(this.num>this.arr.length-1){
        this.removeEventListener("load",this.self.loadHandler);
        var evt=new Event(Method.EVENT_ID);
        evt.list=this.list;
        document.dispatchEvent(evt);
        return;
      }
      this.src=this.arr[this.num];
    },
    $c:function (type,parent,style) {
      var elem=document.createElement(type);
      if(parent) parent.appendChild(elem);
      for(var key in style){
        elem.style[key]=style[key];
      }
      return elem;
    },
    divColor: function () {
      var col="#";//这个字符串第一位为# 颜色的格式
      for(var i=0;i<6;i++){
        col+=parseInt(Math.random()*16).toString(16);//rondom*16后的随机值即为0-1*16==0-16;  toString(16)为转化为16进制
      }
      return col;//最后返回一个七位的值 格式即为#nnnnnn 颜色的格式
    },
    random:function (min,max) {
      max=Math.max(min,max);
      min=Math.min(min,max);
      return Math.floor(Math.random()*(max-min)+min);
    },
    dragElem:function (elem) {
      elem.addEventListener("mousedown",this.mouseDragHandler);
      elem.self=this;
    },
    removeDrag:function (elem) {
      elem.removeEventListener("mousedown",this.mouseDragHandler);
    },
    mouseDragHandler:function (e) {
      if(e.type==="mousedown"){
        e.stopPropagation();
        e.preventDefault();
        document.point={x:e.offsetX,y:e.offsetY};
        document.elem=this;
        this.addEventListener("mouseup",this.self.mouseDragHandler);
        document.addEventListener("mousemove",this.self.mouseDragHandler);
      }else if(e.type==="mousemove"){
        this.elem.style.left=e.x-this.point.x+"px";
        this.elem.style.top=e.y-this.point.y+"px";
      }else if(e.type==="mouseup"){
        this.removeEventListener("mouseup",this.self.mouseDragHandler);
        document.removeEventListener("mousemove",this.self.mouseDragHandler);
      }
    }
  }
})();

html:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <script src="js/Method.js"></script>
</head>
<body>
<script>
  var div;
  var code=[];
  var speed=2;
  var bool=false;
  init();
  function init() {
    div=Method.$c("div",document.body,{
      width:"50px",
      height:"50px",
      backgroundColor:"red",
      position:"absolute",
      left:0,
      top:0
    });
    window.addEventListener("keydown",keyHandler);
    window.addEventListener("keyup",keyHandler);
    setInterval(animation,16);
  }
 
  function keyHandler(e) {
    if(e.type==="keydown" && (!bool || code.indexOf(e.keyCode)===-1)){
      bool=true;
      code.push(e.keyCode);
    }else if(e.type==="keyup"){
      bool=false;
      code.length=0;
    }
  }
 
  function animation() {
    if(!bool)return;
    for(var i=0;i<code.length;i++){
      switch (code[i]){
        case 37:
          div.style.left=div.offsetLeft-speed+"px";
          break;
        case 38:
          div.style.top=div.offsetTop-speed+"px";
          break;
        case 39:
          div.style.left=div.offsetLeft+speed+"px";
          break;
        case 40:
          div.style.top=div.offsetTop+speed+"px";
          break;
      }
    }
  }
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JAVASCRIPT 对象的创建与使用
Mar 09 Javascript
jquery实现可拖拽弹出层特效
Jan 04 Javascript
Javascript中indexOf()和lastIndexOf应用方法实例
Aug 24 Javascript
详解微信小程序——自定义圆形进度条
Dec 29 Javascript
js中编码函数:escape,encodeURI与encodeURIComponent详解
Mar 21 Javascript
微信小程序 动态绑定事件并实现事件修改样式
Apr 13 Javascript
关于Angularjs中自定义指令一些有价值的细节和技巧小结
Apr 22 Javascript
vue父组件异步获取数据传给子组件的方法
Jul 26 Javascript
jQuery+css last-child实现选择最后一个子元素操作示例
Dec 10 jQuery
vue开发环境配置跨域的方法步骤
Jan 16 Javascript
JavaScript函数定义方法实例详解
Mar 05 Javascript
详解javascript中var与ES6规范中let、const区别与用法
Jan 11 Javascript
vue-cli3 取消eslint校验代码的解决办法
Jan 16 #Javascript
jQuery实现数字华容道小游戏(实例代码)
Jan 16 #jQuery
js实现点击生成随机div
Jan 16 #Javascript
关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题
Jan 16 #Javascript
JS实现可视化音频效果的实例代码
Jan 16 #Javascript
js实现div色块碰撞
Jan 16 #Javascript
Vue实现 点击显示再点击隐藏效果(点击页面空白区域也隐藏效果)
Jan 16 #Javascript
You might like
php 搜索框提示(自动完成)实例代码
2012/02/05 PHP
浅析php适配器模式(Adapter)
2014/11/25 PHP
PHP实现的json类实例
2015/07/28 PHP
PHP单例模式详解及实例代码
2016/12/21 PHP
window.open的功能全解析
2006/10/10 Javascript
javaScript 数值型和字符串型之间的转换
2009/07/25 Javascript
客户端 使用XML DOM加载json数据的方法
2010/09/28 Javascript
有关JavaScript的10个怪癖和秘密分享
2011/08/28 Javascript
jquery实现省市select下拉框的替换(示例代码)
2014/02/22 Javascript
jquery实现点击其他区域时隐藏下拉div和遮罩层的方法
2015/12/23 Javascript
详解javascript获取url信息的常见方法
2016/12/19 Javascript
Angularjs中使用layDate日期控件示例
2017/01/11 Javascript
Move.js入门
2017/02/08 Javascript
Nodejs高扩展性的模板引擎 functmpl简介
2017/02/13 NodeJs
使用JQ完成表格隔行换色的简单实例
2017/08/25 Javascript
node.js ws模块搭建websocket服务端的方法示例
2019/04/25 Javascript
有趣的JavaScript隐式类型转换操作实例分析
2020/05/02 Javascript
js实现微信聊天效果
2020/08/09 Javascript
浅谈Python单向链表的实现
2015/12/24 Python
python批量将excel内容进行翻译写入功能
2019/10/10 Python
Pycharm 使用 Pipenv 新建的虚拟环境(图文详解)
2020/04/16 Python
纯css3实现的竖形无限级导航
2014/12/10 HTML / CSS
印尼在线精品店:Berrybenka.com
2016/10/22 全球购物
Vans奥地利官方网站:美国原创极限运动潮牌
2018/09/30 全球购物
俄罗斯电子产品在线商店:UltraTrade
2020/01/30 全球购物
说一下Linux下有关用户和组管理的命令
2014/08/18 面试题
简历自荐信
2013/12/02 职场文书
遗嘱继承公证书
2014/04/09 职场文书
餐饮投资计划书
2014/04/25 职场文书
医学专业大学生求职信
2014/07/12 职场文书
学校政风行风整改方案
2014/10/25 职场文书
收银员岗位职责
2015/02/03 职场文书
物业客服专员岗位职责
2015/04/07 职场文书
《没有任何借口》读后感:完美的执行能力
2020/01/07 职场文书
将图片保存到mysql数据库并展示在前端页面的实现代码
2021/05/02 MySQL
JS class语法糖的深入剖析
2022/07/07 Javascript