В данном уроке я хочу показать вам, как сделать чередование крестика и нолика в одну строчку. Вы скорее всего, сделали что-то такое:
function start(cells) {
let i = 0; // начальное значение счетчика
for (let cell of cells) {
cell.addEventListener('click', function() {
if (i % 2 == 0) {
this.textContent = 'X';
} else {
this.textContent = '0';
}
i++; // увеличиваем счетчик
});
}
}
Я предложу решить задачу короче. Сделаем
массив наших 'игроков'
:
let gamers = ['X', 'O'];
Как вы видите, в этом массиве крестик имеет
ключ 0
, а нолик - ключ 1
. То
же самое можно сказать и про i % 2
- для крестика остаток будет 0
, а
для нолика - 1
.
То есть эту штуку можно использовать вместо ключа:
let gamers = ['X', 'O'];
let key = i % 2;
console.log(gamers[key]);
Или еще короче:
let gamers = ['X', 'O'];
console.log(gamers[i % 2]);
Или еще короче:
console.log(['X', 'O'][i % 2]);
Упростим теперь код нашей функции start
:
function start(cells) {
let i = 0;
for (let cell of cells) {
cell.addEventListener('click', function() {
this.textContent = ['X', 'O'][i % 2];
i++;
});
}
}
Самостоятельно, не подсматривая в мой код, внесите описанную правку.
Сейчас на любую ячейку можно делать неограниченное количество кликов, меняя, например, крестик на нолик. Исправьте это.