так. Наверное дело в какой то мелочи :
export default function Game() {
const [rec, setRec] = useState({
history: [
{
squares: Array(9).fill(null)
}
],
xIsNext: true
});
function handleClick(i) {
const history = rec.history;
const current = history[history.lenght - 1];
const squares = current.squares.slice();
if (calculateWinner(squares) || squares[i]) {
return;
}
squares[i] = rec.xIsNext ? "X" : "0";
setRec({
history: history.concat([
{
squares: squares
}
]),
xIsNext: !setRec.xIsNext
});
}
const history = rec.history;
const current = history[history.lenght - 1];
const winner = calculateWinner(current.squares);
let status;
if (winner) {
status = "Winner is " + winner;
} else {
status = "Next turn: " + (setRec.xIsNext ? "X" : "0");
}
return (
<div className="game">
<div className="game-board">
<Board squares={current.squares} onClick={(i) => handleClick(i)} />
</div>
<div className="game-info">
<div>{status}</div>
<ol>{/* TODO */}</ol>
</div>
</div>
);
}
Ругается на строку const winner = calculateWinner(current.squares); - а точнее на squares
Код проекта полностью - https://codesandbox.io/s/gifted-haibt-vkhtc?file=/src/App.js
length - слово с ошибкой написано
Жесть офигеть, вот так и знал что на какой нибудь фигне) Почти весь день протупил из за невнимательности. Огромное спасибо!)
ты весь день протупил, потому что не знаешь что такое debugger
Действительно. Только слышал. Надо будет погуглить и посмотреть на этом же примере, как надо было его использовать. Спасибо
А можно подробнее, что бы под этим имеешь ввиду кстати - расширение для браузера? или фича в ide? Просто потыкался в инструментах что есть и так и не понял как что то из этого мне могло указать на опечатку слова length А то я тут у себя с новой проблемо встрял. Небольшая игра крестики нолики, появляются кнопки, которые записывают предыдущие хода, но как нажимаю на на одну из них выкидывает ошибку, что не может прочитать значение того или иного хода. Опять таки все пересмотрел, но не могу понять в чем проблема - https://codesandbox.io/s/vigorous-cori-s9rjz?file=/src/App.js
Обсуждают сегодня