js编写简单的贪吃蛇游戏

css代码

*{
        margin: 0;
        padding:0;
    }
    td{
        width: 4px;
        height: 4px;
        background: #ccc;
        border: 2px solid #ccc;
    }
    table{
        margin: 60px auto 0;
        border: 10px solid #333;
        background: #ccc;
    }

 

 

js代码

window.onload = function(){
        snake();
    };

    function snake(){
        //<table><tbody><tr><td></td><td></td><td></td></tr></tbody></table>
        //创建表格的外层,并存入变量
        var oTa =  document.createElement('table');
        var oTb =  document.createElement('tbody');
        //循环生成40*40的表格
        for(var i=0; i<40; i++){
            var oTr = document.createElement('tr');
            //需要生成td
            for(var j=0; j<40; j++){
                var oTd = document.createElement('td');
                //oTd.style = "background:#ccc";
                oTr.appendChild(oTd);
            }
            //将tr放到tbody中
            oTb.appendChild(oTr);
        }

        //将tbody放入table中
        oTa.appendChild(oTb);
        oTa.cellSpacing = '1';
        document.body.appendChild(oTa);

        //约定一下所有的颜色 黑边框#333  大背景#ccc 红点背景red  #555蛇身的颜色 #eee蛇头的颜色
        //随机一个红点,先获取所有的td存起来,以便后续使用
        var aTd = document.getElementsByTagName("td");
        fruit();
        function fruit(){
            var num = Math.floor( Math.random()*aTd.length );

            //判断是否和蛇重复了
            if(aTd[num].style.backgroundColor != 'rgb(238, 238, 238)' && aTd[num].style.backgroundColor != 'rgb(85, 85, 85)'){
                aTd[num].style = 'background:red;border:2px solid #333';
            }else{
                fruit();
            }

        }


        //初始化蛇的位置
        var arr = [[19,20]];
        var rows = oTb.rows;
        var timer = null;
        var keyTimer = null;
        var directionCode = "";
        var snakeMove ="";
        snakeColor();
        function snakeColor(){
            //蛇身的颜色需要设置
            //通过tbody的rows属性可以找到下面的所有tr ,通过tr的cells属性可以找到下面所有td
            for(var i=0; i<arr.length; i++){
                rows[arr[i][0]].cells[arr[i][1]].style = 'background:#555;border:2px solid #333';
            }
            rows[arr[0][0]].cells[arr[0][1]].style = 'background:#eee;border:2px solid #333';     //19 = arr[0][0]   20 = arr[0][1]
        }

        //检测键盘事件
        document.onkeydown = function(e){
            e = e || window.event;
            //console.log(e.keyCode);
            clearTimeout(keyTimer);
            keyTimer = null;
            keyTimer = setTimeout(function(){
                doKeyAction(e.keyCode);
            },20)

            function doKeyAction(keyCo){
                if( keyCo==37||keyCo==38||keyCo==39||keyCo==40 ){
                    if(Math.abs(directionCode-keyCo) == 2 || directionCode == keyCo){
                        return;
                    }else{
                        directionCode = keyCo;
                    }
                }

                //37 38 39 40 左上右下   32空格   enter 13
                switch (keyCo){
                    case 37:
                        //需要执行的代码
                        snakeTimer(0,-1);
                        break;
                    case 38:
                        //上需要执行的代码
                        snakeTimer(-1,0);
                        break;
                    case 39:
                        //右需要执行的代码
                        snakeTimer(0,1);
                        break;
                    case 40:
                        //下需要执行的代码
                        snakeTimer(1,0);
                        break;
                    case 32:
                        //空格需要执行的代码 暂停 继续
                        //snakeTimer(0,-1);
                        if(timer){
                            clearInterval(timer);
                            timer = null;
                        }else{
                            snakeMove && snakeMove();  //  ||   &&        a || b 如果a为真,就不会执行b        a && b 如果a为真才会执行b
                        }
                        break;
                }
            }
            

            //运动的timer
            function snakeTimer(y,x){
                snakeMove = function(){
                    snakeTimer(y,x);
                };
                clearInterval(timer);  //TUDO这里的清除timer只是暂时处理
                timer = setInterval(function(){
                    //console.log( [arr[0][0],arr[0][1]-1] );

                    //当达到25个的时候,进入下一关
                    if(arr.length >=25){
                        clearInterval(timer);
                        alert("恭喜,进入下一关");
                        window.snakeSpeed = window.snakeSpeed*0.8;
                        document.body.removeChild(oTa);
                        snake();
                    }

                    //检测是否碰到边缘了
                    if(arr[0][0]+y<0 || arr[0][0]+y>39 || arr[0][1]+x<0 || arr[0][1]+x>39){
                        fail();
                        return;
                    }

                    //检测是否撞到自己了
                    for(var i=1; i<arr.length; i++){
                        if(arr[0][0]+y == arr[i][0] && arr[0][1]+x == arr[i][1]){
                            fail();
                            return;
                        }
                    }




                    arr.unshift( [arr[0][0]+y,arr[0][1]+x] );  //arr.unshift(新值),在arr最前面插入一个(新值)
                    //是否遇到红色的块了
                    if(rows[arr[0][0]].cells[arr[0][1]].style.backgroundColor == 'red'){
                        //console.log("已经迟到水果了");
                        //重新去生成以红点
                        fruit();
                        //console.log(arr);
                    }else{
                        rows[arr[arr.length-1][0]].cells[arr[arr.length-1][1]].style =  'background:#ccc;border:2px solid #ccc';          //如何寻找数组的最后一个,arr[arr.length-1]
                        arr.pop();
                    }
                    snakeColor();

                },window.snakeSpeed);
            }


            function fail(){
                clearInterval(timer);
                alert("任务失败");
                //TODO:任务失败后重新加载游戏
                document.body.removeChild(oTa);
                snake();
            }

        };

        if(!window.snakeSpeed){
            alert("点击方向键开始游戏,点击空格暂停");
            window.snakeSpeed = 100;
        }


    }