• 회원가입
  • 로그인
  • 구글아이디로 로그인

[Basic] JS - rest (나머지 기타등등) 매개변수

rest 매개변수 예제 - 매개변수 총합

 

<div id="hz"></div>

 

<script>

function sum(...nums) {

    return nums.reduce((previous, current) => {

        return previous + current;

    });

}


document.getElementById('hz').innerHTML += sum(1, 2, 3) + "<br>";

// 결과값: 6


document.getElementById('hz').innerHTML += sum(1, 2, 3,4) + "<br>";

// 결과값: 10

</script>

 

결과보기

 

rest 매개변수 정의

 

정해지지 않은 수(an indefinite number, 부정수) 매개변수를 배열로 표현.

 


 

주요 최신 브라우저 모두 지원. (단, IE 지원 X)

 

 

rest 매개변수 구문

 

function homzzang(a, b, ...rest) {

    // 함수 실행구문

}



※ homzzang : 함수명

※ ...rest : rest 매개변수

 

1. 함수 마지막 매개변수명 앞에 ... (마침표 3개) 붙임.

2. rest 글자는 임의의 글자로 작성 가능.

3. 마지막 매개변수만 rest 매개변수 될 수 있음.

4.  (사용자가 제공한) 모든 rest 매개변수를 "표준" JS 배열로 대체. 

 


rest 매개변수 예제 - rest 매개변수를 표준 JS 배열로 반환.

 

<script>

function homzzang(site, host, ...codes) {

  console.log("사이트", site); 

  console.log("호스트", host);

  console.log("codes", codes); 

}


homzzang("홈짱닷컴", "Homzzang.com", "HTML", "CSS", "JS");

<script>

 

결과보기  (※ codepen 좌측 맨 하단 console 버튼 클릭 후 결과 확인.)


PS. 결과값

 

"사이트" "홈짱닷컴"

"호스트" "Homzzang.com"

"codes" ["HTML", "CSS", "JS"]

 

PS. 더 깊게 공부하고 싶은 분은 아래 좌표 이용.

https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Functions/rest_parameters

 


분류 제목
js JS - Keyboard KeyCode (키보드키코드 = 키보드키번호 = 키보드키조회 = 키보드코드 = 키보…
js JS - ctrlKey, altKey, shiftKey 속성 - Ctrl키, Alt키, Shift키 눌림여부…
js JS - 숫자만 입력 가능
js JS - 클릭버튼생성 (= 클릭탭생성), 자식요소개별아이디부여, 클릭요소삭제 (= 클릭요소제거 = 클릭부모요…
js JS - F12키차단 (=개발자도구차단) + 마우스오른쪽금지 (= 마우스오른쪽차단 = 불펌방지 = 클릭방지)
js JS - Drag & Drop (= Draggable) - 요소이동 (= 요소끌어이동 = 드래그앤드롭 = 드…
js JS - INPUT입력값을 GET방식으로 넘기기 (=인풋값, 인풋입력밧, 겟방식전달)
HTML_Objects JS - <thead> 객체 - 테이블머리글그룹 (= 테이블헤드그룹 = thead태그 = 티헤드태그) (HT…
js JS - 아이피 유효성검사 (= 아이피 유효성체크 = 아이피 적합성검사 = 아이피 적합성체크)
DOM_Event JS - DOMContentLoaded 이벤트 ★★★★★ - 돔 웹문서 로드 완료 이벤트(= DOMConte…
js JS - Lazyload (레이지로드)
js JS - 스크롤고정 스크롤스파이 메뉴 (= 매뉴얼메뉴 Smooth Scrolling Sticky Scroll…
js JS - 마우스오버 시, 오디오재생 (= mp3재생 = 소리재생)
js JS - 숫자제거 공백제거 정규표현식
js JS - 3D 입체 영상 (= 입체 화면 = 이미지 파노라마 360도 회전 영상 = Image Panoram…
js JS - m3u8 ★ (동영상재생 + 플레이어 다운 + 동영상다운로드 : 엠삼유팔 = 엠쓰리유팔 )
js JS - 이전페이지 보내기 (= 기존페이지로 돌아가기) 3가지방법
js JS - 각종 게임 무료다운로드 주소 좌표 (= 게임다운좌표)
js JS - 서브도메인 입력 후 해당 주소로 이동
js JS - 예약어 (= 변수명・라벨명・함수명 등으로 사용 불가능한 단어)
62/67
목록
찾아주셔서 감사합니다. Since 2012