原生javascript制作贪吃蛇小游戏的方法分析


Posted in Javascript onFebruary 26, 2020

本文实例讲述了原生javascript制作贪吃蛇小游戏的方法。分享给大家供大家参考,具体如下:

<!--1、 创建场景 -->
<!-- 2、定义初始数据  以及随机食物 -->
<!-- 3、控制贪吃蛇方向 -->
<!-- 4、判断位置以及和随机食物的位置 增加贪吃蛇长度 -->

HTML部分

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title></title>
  <style>
    html,body{
      width: 100%;
      height: 100%;
      overflow: hidden;
    }
    * {
      margin: 0;
      padding: 0;
    }
    li{
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background: chocolate;
      position: absolute;
      left: 240px;
      top: 60px;
      z-index: 1;
      list-style: none;
    }
    #box{
      position: absolute;
      left:240px;
      top: 50px;
      width:800px;
      height:600px;
    }
  </style>
</head>
<body>
  <span>
    游戏玩法:上下左右控制小蛇的方向。
    撞到边缘游戏结束。
    长按方向键即可加速。
  </span>
  <ul id="box">
    <li></li>
    <li></li>
    <li></li>
  </ul>
</body>

js开始

function $(id){
    return document.getElementById(id);
  }
  window.onload = function () {
    // 创建背景
    js_background();
    // 随机食物
    js_food();
    // 创建贪吃蛇
    create_snake();
    document.onkeydown = function(event){
      let evt = event || window.event;
      switch (evt.keyCode) {
        case 37:direction="left";break;
        case 38:direction="up";break;
        case 39:direction="right";break;
        case 40:direction="down";break;
        default:;
        // console.log(evt.keyCode);
      }
      start_snake()
    }
  }

//贪吃蛇方向// 创建背景

// 贪吃蛇方向// 创建背景
  var direction = "right";
  // 创建背景
  function js_background(){
    let bg = document.createElement("div");
    bg.id = "js_bg";
    bg.style.cssText = "position:relative;margin :50px auto; background:skyblue; width:800px; height:600px;";
    document.body.appendChild(bg);
  }

//随机食物

var food_left = 0;
  var food_top = 0;
  function js_food(){
    food_left = parseInt(Math.random()*800/20)*20;
    food_top = parseInt(Math.random()*600/20)*20;
    let foodDiv = document.createElement("div");
    foodDiv.style.cssText = "position:absolute;width:20px; height: 20px; border-radius:50%; background:yellow;";
    foodDiv.style.left = food_left+"px";
    foodDiv.style.top = food_top+"px";
    foodDiv.id = "foodDiv";
    $("js_bg").appendChild(foodDiv);
  }

//创建贪吃蛇

function create_snake(){
    let lis = document.getElementsByTagName("li");
    lis[0].style.backgroundColor = "black";
    lis[0].style.zIndex = 1;
    for(let i = 0; i < lis.length; i++){
      lis[i].style.left = 280-(i*20)+"px";
      lis[i].style.top = 60+"px";
    }
  }

//定时器

// 定时器
  let timre = setInterval(start_snake,200);
  let lis = document.getElementsByTagName("li");
  function start_snake(){
    let left=parseFloat(lis[0].style.left);
    let top= parseFloat(lis[0].style.top);
    // console.log(top)
    switch (direction) {
      case "left":left = (left-20);break;
      case "up":top = (top-20);break;
      case "right":left = (left+20);break;
      case "down":top = (top+20);break;
      default:;
    }
    if(left<0 || left>800-20 || top<0 || top>600-20){
        window.clearInterval(timre);
        alert("亲,您Game Over");
        return;
    }
    // for(let i = 1; i <= lis.length-1; i++){
    //   lis[i].style.left = lis[i-1].style.left;
    //   lis[i].style.top = lis[i-1].style.top;
    // }
    for(var i=lis.length-1;i>0;i--){
      lis[i].style.left = lis[i-1].style.left;
      lis[i].style.top = lis[i-1].style.top;
    }
    // 改变第一节
    lis[0].style.left = left+"px";
    lis[0].style.top = top+"px";
    // console.log(food_top+"----------");
    // console.log(top);
    if(left == food_left && top == food_top){
      eat();
    }
  }
  function eat() {
    $("js_bg").removeChild($("foodDiv"));
    js_food();
    // alert("ll");
    let li = document.createElement("li");
    $("js_bg").appendChild(li);
    // create_snake();
  }

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
通过jQuery打造支持汉字,拼音,英文快速定位查询的超级select插件
Jun 18 Javascript
探讨在JQuery和Js中,如何让ajax执行完后再继续往下执行
Jul 09 Javascript
jquery操作checkbox示例分享
Jul 21 Javascript
node.js中的fs.fchownSync方法使用说明
Dec 16 Javascript
初识Node.js
Mar 20 Javascript
jQuery插件imgPreviewQs实现上传图片预览
Jan 15 Javascript
通过jquery-ui中的sortable来实现拖拽排序的简单实例
May 24 Javascript
jQuery实现三级联动效果
Mar 02 Javascript
jQuery+CSS3实现点赞功能
Mar 13 Javascript
Vue路由切换时的左滑和右滑效果示例
May 29 Javascript
vue slot与传参实例代码讲解
Apr 28 Javascript
生产制造追溯系统之在线打印功能
Jun 03 Javascript
javascript 数组精简技巧小结
Feb 26 #Javascript
vue父子模板传值问题解决方法案例分析
Feb 26 #Javascript
jquery实现直播视频弹幕效果
Feb 25 #jQuery
JavaScript实现打砖块游戏
Feb 25 #Javascript
深入理解Antd-Select组件的用法
Feb 25 #Javascript
京东优选小程序的实现代码示例
Feb 25 #Javascript
手把手带你入门微信小程序新框架Kbone的使用
Feb 25 #Javascript
You might like
PHILIPS L4X25T电路分析和打理
2021/03/02 无线电
PHP 类相关函数的使用详解
2013/05/10 PHP
ThinkPHP5分页paginate代码实例解析
2020/11/10 PHP
JS防止用户多次提交的简单代码
2013/08/01 Javascript
javascript删除元素节点removeChild()用法实例
2015/05/26 Javascript
解析JavaScript的ES6版本中的解构赋值
2015/07/28 Javascript
JavaScript识别网页关键字并进行描红的方法
2015/11/09 Javascript
JavaScript动态添加css样式和script标签
2016/07/19 Javascript
JS验证不重复验证码
2017/02/10 Javascript
javascript获取以及设置光标位置
2017/02/16 Javascript
微信浏览器禁止页面下拉查看网址实例详解
2017/06/28 Javascript
jQuery中过滤器的基本用法示例
2017/10/11 jQuery
React-router4路由监听的实现
2018/08/07 Javascript
Vue+webpack+Element 兼容问题总结(小结)
2018/08/16 Javascript
Vue全局loading及错误提示的思路与实现
2019/08/09 Javascript
[54:43]DOTA2-DPC中国联赛 正赛 CDEC vs Dynasty BO3 第一场 2月22日
2021/03/11 DOTA
Python库urllib与urllib2主要区别分析
2014/07/13 Python
python读取json文件并将数据插入到mongodb的方法
2015/03/23 Python
Python中使用第三方库xlrd来写入Excel文件示例
2015/04/05 Python
编写Python脚本来获取Google搜索结果的示例
2015/05/04 Python
Python守护进程用法实例分析
2015/06/04 Python
Python list操作用法总结
2015/11/10 Python
python制作企业邮箱的爆破脚本
2016/10/05 Python
用python生成(动态彩色)二维码的方法(使用myqr库实现)
2019/06/24 Python
django 多对多表的创建和插入代码实现
2019/09/09 Python
Python.append()与Python.expand()用法详解
2019/12/18 Python
基于python实现可视化生成二维码工具
2020/07/08 Python
CSS3弹性布局内容对齐(justify-content)属性使用详解
2017/07/31 HTML / CSS
Html5实现iPhone开机界面示例代码
2013/06/30 HTML / CSS
外企测试工程师面试题
2015/02/01 面试题
领导班子自我剖析材料
2014/08/16 职场文书
国际残疾人日广播稿范文
2014/10/09 职场文书
秦始皇兵马俑导游词
2015/02/02 职场文书
承诺保证书格式
2015/02/28 职场文书
运动会闭幕式致辞
2015/07/29 职场文书
2016年学校十一国庆节活动总结
2016/04/01 职场文书