티스토리 뷰
1. 함수 선언문과 표현식의 차이 : 호이스팅
함수 내에서 foo와 bar를 정의하면, 함수의 맨 윗 부분으로 끌어올려져 전역 변수를 덮어쓰게 된다.
2. 함수 반환하기
함수는 객체이기 때문에 반환값으로 사용될 수 있다.
setup()은 반환된 함수를 감싸고 있기 때문에 클로저를 생성한다.
클로저는 코드 외부에서 접근할 수 없기 때문에, 비공개 데이터 저장을 위해 사용할 수 있다.
3. 자기 자신을 정의하는 함수
이 패턴은 함수가 어떤 초기화 작업을 단 한 번만 수행할 경우, 자기 자신을 재정의하여 구현 내용을 갱신하는 용도로 사용된다.
재정의된 함수의 작업량이 적기 때문에 애플리케이션 성능에 도움이 된다.
단점
- 자기 자신을 재정의한 이후에는 원본에 추가했던 프로퍼티들을 찾을 수 없게 된다
- 다른 변수에 할당되거나, 객체의 메서드로 사용되면 재정의된 부분이 아닌 원본 함수의 본문이 실행된다.
일급 객체로 사용 예
마지막에 전역 scareMe()가 호출되었을 때 재정의한 본문이 처음으로 실행되며, property도 더이상 참조할 수 없게 된다.
4. 즉시 실행 함수
즉시 실행 함수의 매개변수
일반적으로 인자를 너무 많이 전달하지 않는 것이 좋다.
즉시 실행 함수의 반환 값
어떤 객체의 프로퍼티가 객체의 생명주기 동안 값이 변하지 않고, 처음에 정의할 때는 적절한 계산 작업이 필요한 경우
이 작업을 즉시 실행 함수로 감싼 후, 즉시 실행 함수의 반환 값을 프로퍼티 값으로 할당한다.
5. 즉시 객체 초기화
6. 메모이제이션 패턴
7. 설정 객체 패턴
function addPerson(first, last, dob, gender, address) {...}
addPerson("Bruce", "Wayne", new Date(), null, null, "batman");
매개변수가 많은 함수를 호출할 때는 선택적인 매개변수도 전달해야 하며, 매개변수의 순서가 뒤섞이지 않게 주의해야 한다.
모든 매개변수를 하나의 객체로 만들어 대신 전달하는 방법이 더 낫다.
var conf = {
username: "batman",
first: "Bruce",
last: "Wayne"
};
addPerson(conf);
설정 객체의 장점
- 매개변수와 순서를 기억할 필요가 없다.
- 선택적인 매개변수를 안전하게 생략할 수 있다.
- 읽기 쉽고 유지보수하기 편한다.
- 매개변수를 추가하거나 제거하기가 편하다.
단점
- 매개변수의 이름을 기억해야 한다.
- 프로퍼티의 이름은 압축되지 않는다.
이 패턴은 함수가 DOM 엘리먼트 생성할 때나 CSS 스타일을 지정할 때 유용하다.
'JavaScript' 카테고리의 다른 글
함수 선언 (0) | 2017.12.30 |
---|---|
자바스크립트 패턴 - 객체 생성 패턴 (0) | 2017.10.28 |
자바스크립트 패턴 - 리터럴과 생성자 (0) | 2017.09.23 |
자바스크립트 패턴 - 코드 작성 기초 (0) | 2017.09.22 |
웹 페이지 pdf 생성하기 (0) | 2017.09.22 |