• TOC {:toc}

이 글은 생활코딩의 함수 예고, 함수, 함수의 활용 강의내용을 복습하기 위해 강의 자료를 기반으로 작성한 글입니다.

  • 제가 필요한 부분 위주로 확인하면서 정리하고 있어 글에 덜 작성된 부분이 있을 수 있습니다.
  • 글 작성 후 원 강의의 내용이 수정되거나 내용을 이해하기 위한 개인적인 설명이나 해석이 있을 수 있습니다. 되도록 원 강의를 참고해주시길 바랍니다.
  • 잘못된 부분이 있다면 댓글이나 그 외 편하신 방법으로 알려주시면 감사하겠습니다.

21. 함수 예고

함수: 많아지고 복잡해진 코드를 정리정돈하는 용도

동일한 JavaScript를 실행하는 버튼이 많아지면 해당 JavaScript를 모든 버튼에서 동일하게 유지하거나 일괄적으로 수정하기 어렵다. → 중복된 JavaScript 코드를 함수로 만들어서 실행.

함수는 다음과 같이 정의한 뒤 사용할 수 있다.

  • 세부적인 사항은 이후 강의에서 설명
/* 함수를 정의 */
/* 이전에 onclick의 속성 값으로 입력했던 코드를 잘라내서 붙여 넣는다*/ 
function nightDayHandler (self) {
    var target = document.querySelector('body')

    if(self.value === night) {
        target.style.backgroundColor = 'black';
        target.style.color = 'white';
        self.value = 'day'
    }

    var alist = document.querySelectorAll('a');

    var i = 0;
    while(i < alist.length) {
        alist[i].style.color = 'powderblue';
        i = i + 1;
    }

    /* day인 경우에 대해서도 작성 */
    else {...}
}
<!-- 함수를 호출 -->
<input id = "night_day" type = "button" value = "night"
    onclick = "nightDayHandler(this);">

함수를 사용하면 다음과 같은 이점이 있다.

  • 반복되는 코드의 양을 줄일 수 있다.
  • 동일한 기능에 대해서 동일한 코드를 유지할 수 있다.
  • 반복되는 기능을 일괄적으로 수정하기에 용이하다.
  • 함수 이름을 지정하면 기능을 직관적으로 파악하기 쉽다.

22. 함수

함수의 기본

함수는 사용하기 위한 문법을 보면,

/* 함수를 정의 */
/* function 함수명의 형태로 적은 뒤 {}안에 코드를 입력 */
function two() {
    document.write('<li>2-1</li>')
    document.write('<li>2-2</li>')
}

/* 함수 호출(사용) */
document.write('<li>1</li>');
/* list 2-1, 2-2를 출력 */
two();
document.write('<li>3</li>');
/* list 2-1, 2-2를 다시 출력 */
two();

매개변수(parameter)와 인자(argument)

함수는 입력에 따라 출력을 내어준다는 것에서 자판기와 비슷한다. 함수는 인자(argument)를 매개변수(parameter)로 입력 받아서 결과값(result) 내어준다.

이전까지는 별도의 입력값 없이 함수를 실행

/* 1 + 1 만 수행해서 2를 출력하는 함수 */
function onePlusOne() {
    document.write(1 + 1);
}

/* 함수 실행 */
onePlusOne();

매개변수를 이용하면 값을 직접 입력해서 더한 결과를 출력할 수 있다.

/* 더하고 싶은 두 수를 left, right라는 매개변수로 가져오는 함수 */
function sum(left, right) {
    /* left와 right를 더한 값을 출력 */
    document.write(left + right);
}

/* 2와 3을 더하는 함수. 5출력 */
/* 함수 호출시 함수로 전달하는 값을 인자라고 한다 */
sum(2, 3);

/* 3과 4를 더하는 함수. 7출력 */
sum(3, 4);

더한 결과를 ‘출력’만 하지 않고 다양한 방법을 사용하고 싶으면 return을 이용해서 함수가 결과 값을 대변할 수 있게 한다.

function sum2(left, right) {
    /* left + right를 출력하지 않고 return */
    return left + right;
}

/* sum2(left,right)를 left + right의 표현식처럼 사용할 수 있다 */

/* 5(=2 + 3)를 출력 */
document.write(sum2(2, 3))
/* 5에 <div>태그로 효과를 주면서 출력 */
document.write('<div style = "color: red;">' + sum2(2, 3) + '</div>')

return이 없다면 예시같이 새로운 기능을 따로 쓰고싶을 때 마다 함수를 새로 정의해야 한다.

23. 함수의 활용

함수를 이용해서 night & day handler 리팩토링 할 수 있다.

  1. 적절한 이름을 사용해서 함수를 정의한다.

    function nightDayHanler() {}
    
  2. 함수로 만들고 싶은 코드(onclick의 속성값)를 함수 내에 붙여넣는다.

    • 코드의 this는 현재 코드가 속해있는 요소를 가리킨다.
    • onclick의 속성값으로 있을 때는 this가 버튼을 가리켰으나 따로 빼서 함수를 만들면 더 이상 버튼을 가리키지 않는다.
    /* this대신 매개변수 self를 받아 사용하고 */
    function nightDayHandler (self) {
        var target = document.querySelector('body')
    
        if(self.value === night) {
            target.style.backgroundColor = 'black';
            target.style.color = 'white';
            self.value = 'day'
        }
    
        var alist = document.querySelectorAll('a');
    
        var i = 0;
        while(i < alist.length) {
            alist[i].style.color = 'powderblue';
            i = i + 1;
        }
    
        /* day인 경우에 대해서도 동일하게 작성 */
        else {...}
    }
    
    <!-- 버튼에서 함수를 호출하면서 this를 매개변수의 인자로 보내면 해결 가능하다 -->
    <input type = "button" value = "night" onclick = "nightDayHandler(this);"