Programming Languages/JS
Javascript/ DOM queryselectorAll을 활용하자!
YUYA
2021. 1. 7. 13:51
틱텍토 게임
오늘 과제로 간단한 틱텍토 게임을 만들었다. 사진 처럼 빙고 칸 안에 o와 x를 표시하는 기능이 전부.
문제의 코드
var block_one = document.querySelector('#one')
var block_two = document.querySelector('#two')
var block_three = document.querySelector('#three')
var block_four = document.querySelector('#four')
var block_five = document.querySelector('#five')
var block_six = document.querySelector('#six')
var block_seven = document.querySelector('#seven')
var block_eight = document.querySelector('#eight')
var block_nine = document.querySelector('#nine')
빈칸 하나하나를 전부 변수 만들어줬다. 동작은 하지만 만들면서 너무 지저분하다는 생각이 들었다.
var block = document.querySelector('th')
처음에는 위의 코드 블럭처럼 모든 빈칸을 아우르는 변수 하나만 선언하려고 했는데, 작동하지 않았기 때문 ㅠ__ㅠ
원인
문제는 간단했다. querySelector는 해당 셀렉터 내용 중 제일 첫 번째 것만 선택한다.
따라서, 아홉 개 칸 모두를 아우르지않고, 첫 번째 칸만 선택 되기 때문에
내가 이후에 어떤 함수를 작동하든, 첫 번째 칸에만 적용된다.
해결
querySelectorAll을 사용하면 된다!
var blocks = document.querySelectorAll('th');
그럼 모든 칸이 하나의 배열(실은 NodeList)로 담긴다. 각각의 칸에는 인덱스로 접근.
참고
querySelectorAll에서 선택 된 요소들의 배열이 담긴 변수의 모습