메뉴 건너뛰기

조회 수 498 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

체크박스나 라디오등을 제어하다보면 jQuery에 의존해서 많이 사용하게 되는데 순수 javascript만의 힘으로 제어하는 방법을 알아보겠습니다.

 

생각보다 사용법이 jQuery와 많이 다르지 않으며 비슷하기에 어렵지 않을 것입니다.

무엇보다도 추가적으로 라이브러리(jQuery)가 필요하지 않기에 빠르기도하고 간단하게 데이터를 확인할 수 있습니다.

 

 

체크박스의 체크 유무

먼저 체크박스값에 체크가 되어있는지 확인해보겠습니다.

.checked 를 통해 체크 유무를 검사할 수 있습니다.

 

html

<input type="checkbox" name="test1" value="test1">TEST1

 

js

var chk = document.querySelector("input[name=test1]").checked;
console.log(chk);

 

결과

 

체크가 해제되어있으면 false
체크되어 있다면 true

 

 


체크된 체크박스의 값 가져오기

이번에는 취미생활에 체크된 데이터의 value를 가져와 보겠습니다.

 

hobby.html

<form>
    <input type="checkbox" name="hobby" value="music">음악감상
    <input type="checkbox" name="hobby" value="game">게임
    <input type="checkbox" name="hobby" value="travel">여행
    <input type="checkbox" name="hobby" value="soccer">축구
    <input type="checkbox" name="hobby" value="reading">독서
    <input type="checkbox" name="hobby" value="cooking">요리
</form>

 

hobby.js

var chkList = document.querySelectorAll("input[name=hobby]:checked");
chkList.forEach(function (ch) {
    console.log(ch.value);
});

 

결과

 

 

querySelectorAll을 활용하여 name속성이 hobby인 데이터 중에 :checked속성이 있는 데이터만 추출하여 chkList에 담아두었습니다.

 

해당부분을 특정 배열에 push하여 담아도 되고, 문자열에 붙여서 처리하면 될 것 같습니다.


모든 체크박스 선택하기

게시판이나 여러 형태를 작성하다보면 특정값이 모두 선택되게 해야하는 경우가 있습니다.

change 이벤트를 추가하여 제어해보겠습니다.

 

 

결과

 

전체선택

 

hobbyAll의 요소를 선택하여 change 이벤트가 발생하게 되면

name값이 hobby인 데이터를 모두 찾아 속성값을 전체선택된 데이터값으로 변경처리를 해줍니다.


List of Articles
번호 제목 날짜 조회 수
47 setTimeout() / clearTimeout() / setInterval() 2016.12.22 8162
46 드롭다운 메뉴를 만들어보자! -1탄 file 2015.02.03 8171
45 2단계 트리메뉴 마우스오버(mouseover), 온포커스(onfocus) 구현 2015.04.06 8205
44 [단축키 설정 자바스크립트]shortcut.js 2016.12.22 8375
43 페이지 로드 할때 컨트롤에 포커스 주기 2015.02.03 8500
42 Location 객체 - URL 파싱 - URL에서 전달인자 추출하기 함수 작성 file 2015.06.19 8523
41 [INPUT BOX] 텍스트박스(INPUT 박스) 가 동적으로 추가,삭제됩니다 2017.02.19 8526
40 마우스 드래그, 오른쪽 팝업메뉴, 선택 막기 (IE11, 파이어폭스, 크롬 확인) 2015.06.19 8577
39 특정부위 마우스 오버시 설명을 보여주는 소스 2014.03.17 8697
38 주민등록번호로 성별/나이/연령대 구분 2014.03.01 8794
37 자바스크립트 실행 시간 측정 2016.12.22 8930
36 5초후 자동으로 창닫기 2015.02.03 9034
35 자바스크립트 API 문서 2015.06.19 9087
34 이미지 마우스 드래그로 스크롤을 움직이는 소스 2014.03.17 9362
33 location.href 로 새창 여는 방법 (target=_blank 효과) 2015.06.19 9407
32 'onmouseover', 마우스 오버 효과 - 글씨 바꾸기! file 2015.02.03 9436
31 javascript 화면 캡쳐 2016.11.17 9821
30 Javascript selectbox selected 컨트롤 file 2018.06.21 10058
29 예제 - 자바스크립트로 현재 달의 달력 만들기 (calendar) 2015.06.19 10063
28 자바스크립트 영문입력, 숫자만입력, 한글만 입력, 붙여넣기 방지 2015.02.02 10180
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved