开发者问题收集

无法弄清楚如何修复未捕获的 TypeError。

2018-02-21
55

我不断收到一条消息,提示未捕获类型错误“无法将属性‘innerHTML’设置为 null”

我正在尝试使用 html/css/javascript 创建一个推箱子游戏。游戏板是我遇到问题的地方,无论我做什么,它都不会显示。 代码对我来说似乎没问题

过去一个小时我一直在尝试修复它,但我真的不知道我做错了什么。

这是我的代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8" />
    <title>Sokoban</title>
    <meta name="description" content = "The Sokoban Game">
    <meta name="author" content="PHP Class">

    <link rel="stylesheet" href="sokobanstyling.css"> 


</head>

<body>
    <h1>Sokoban</h1>

    <input type="text" id="txtUsername" placeholder="Your name here"/>
    <button onclick="printBoard()">Press ME</button>

<script>


var gBoard = buildBoard ();  

function buildBoard () {
    var board = new Array(6); 

    for (var i=0; i<board.length; i++){
        board[i] = new Array(5); 
    }

   for (var i=0; i<board.length; i++) {
       for (var j=0; j<board[0].length; j++){
           if (i == 0 || i == board.length-1 || j == 0 || j == board[0].length-1) {
               board[i][j] = "WALL"; 

           } else {
               board[i][j] = "FLOOR"; 
           }
        }
    }

    console.log(board);
    return board; 
}

function printBoard() {

    var tblBoard = document.getElementById('tblBoard'); 
    var strHTML = ''; 
    for (var i=0; i<gBoard.length; i++){
        console.log(gBoard[i]); 
        for (var j=0; j<gBoard[0].length; j++) {
            strHTML += "<td>A"; 
            /*
            if (gBoard[i][j] == "WALL") 
            } else if (gBoard[i][j]=="WALL") {

            }
            */
            strHTML += "</td>"; 
        }
        strHTML += "</tr>"; 
    }

    tblBoard.innerHTML = strHTML; 
}


</script>




</body>
</html>
1个回答

您正尝试通过 Id 获取一个不存在的元素

var tblBoard = document.getElementById('tblBoard'); 

然后尝试访问此元素的 innerHTML

tblBoard.innerHTML = strHTML; 

使用 id="tblBoard" 设置您要在那里修改的任何元素的 id

Dakota Raymond
2018-02-21