原生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 相关文章推荐
eclipse如何忽略js文件报错(附图)
Oct 30 Javascript
如何将网页表格内容导入excel
Feb 18 Javascript
jQuery控制的不同方向的滑动(向左、向右滑动等)
Jul 18 Javascript
javascript中sort()的用法实例分析
Jan 30 Javascript
jQuery制作效果超棒的手风琴折叠菜单
Apr 03 Javascript
jQuery实用技巧必备(上)
Nov 02 Javascript
jQuery-1.9.1源码分析系列(十)事件系统之事件体系结构
Nov 19 Javascript
Bootstrap每天必学之导航
Nov 26 Javascript
javascript 小数乘法结果错误的处理方法
Jul 28 Javascript
基于ajax和jsonp的原生封装(实例)
Oct 16 Javascript
处理JavaScript值为undefined的7个小技巧
Jul 28 Javascript
Javascript中Math.max和Math.max.apply的区别和用法详解
Aug 24 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
PHP+DBM的同学录程序(1)
2006/10/09 PHP
PHP 各种排序算法实现代码
2009/08/20 PHP
PHP获取和操作配置文件php.ini的几个函数介绍
2013/06/24 PHP
php使用explode()函数将字符串拆分成数组的方法
2015/02/17 PHP
PHP常见错误提示含义解释(实用!值得收藏)
2016/04/25 PHP
php 中奖概率算法实现代码
2017/01/25 PHP
laravel config文件配置全局变量的例子
2019/10/13 PHP
JavaScript Date对象使用总结
2009/05/14 Javascript
JavaScript 类型的包装对象(Typed Wrappers)
2011/10/27 Javascript
获取服务器传来的数据 用JS去空格的正则表达式
2012/03/26 Javascript
nodejs教程之制作一个简单的文章发布系统
2014/11/21 NodeJs
初识简单却不失优雅的Vue.js
2016/09/12 Javascript
微信小程序 教程之条件渲染
2016/10/18 Javascript
JavaScript中遍历的十种方法总结
2020/12/15 Javascript
Nodejs 数组的队列以及forEach的应用详解
2021/02/25 NodeJs
win7安装python生成随机数代码分享
2013/12/27 Python
Python常见数据结构详解
2014/07/24 Python
python+selenium实现自动抢票功能实例代码
2018/11/23 Python
解决Pycharm 导入其他文件夹源码的2种方法
2020/02/12 Python
Python os模块常用方法和属性总结
2020/02/20 Python
解决python的空格和tab混淆而报错的问题
2021/02/26 Python
css3教程之倾斜页面
2014/01/27 HTML / CSS
CSS3中的Transition过度与Animation动画属性使用要点
2016/05/20 HTML / CSS
施华洛世奇英国官网:SWAROVSKI英国
2017/03/13 全球购物
美国婴儿和儿童家具网上商店:ABaby.com
2018/07/02 全球购物
捷克移动配件网上商店:ProMobily.cz
2019/03/15 全球购物
eBay奥地利站:eBay.at
2019/07/24 全球购物
德国咖啡批发商:Coffeefair
2019/08/26 全球购物
电子技术专业中专生的自我评价
2013/12/17 职场文书
快餐店的创业计划书范文
2014/01/29 职场文书
岗位廉洁从业承诺书
2014/03/28 职场文书
2019职场单身人才调研报告:互联网行业单身比例最高
2019/08/07 职场文书
经典格言警句:没有热忱,世间便无进步
2019/11/13 职场文书
springboot临时文件存储目录配置方式
2021/07/01 Java/Android
Java 实战项目之家居购物商城系统详解流程
2021/11/11 Java/Android
Linux中各个目录的作用与内容
2022/06/28 Servers