즉시 실행 함수( Self-Excuting Anonymous Functions)
/**
* 작성 방법
* (function(){})() 또는 (function(){}())
*/
(function (global, undefined) {
// 독립된 공간(Scope)에 코드 작성
})(window !== undefined ? window : this);
함수는 별도의 독립된 공간(Scope)을 형성한다
/**
* 오늘날 자바스크립트는 전역(Window) 공간을 오염시키지 않는 것이 중요하다.
* 필요하다면 명시적으로 `global`을 붙여서 외부 모듈과 공유하도록 한다.
* 가급적 `var`를 붙여서 지역 변수 생성
*/
(function (global, undefined) {
// 지역 내에서만 사용 가능한 로컬 함수
var _localFn = function() {
// ....
};
// 전역 변수 gFn에 로컬 함수 _localFn 참조 (전역 공유)
global.gFn = _localFn;
})(window !== undfined ? window : this);
함수 내부에서 this 가 참조하는 대상
// 일반함수
function normalFn() {
console.log(this); // 함수가 실행되는 컨텍스트(문맥)
};
// 일반함수 실행
normalFn(); // this === window
document.onclick = normalFn; // this === document
document.querySelector('a.ext').onmouseenter = normalFn; // this === a.ext
// 생성자 함수
function ConstructorFn() {
console.log(this); // 생성자 함수 내 this는 생성된 객체를 가리킴.
}
// new 연산자를 붙여 생성자 함수 실행 - 객체 생성
var instance = new ConstructorFn; // this === instance 객체
생성자 함수(클래스) 사용 예
Navigation 객체 생성자와 프로토타입
// 객체 생성하는 함수 : 생성자 함수 (Constructor Function)
function Navigation(el) {
this.el = document.querySelector(el);
this.children = this.el.querySelectorAll('a');
this.childrenLength = this.children.length;
};
// 생성자 함수의 프로토타입 : 생성되는 객체의 원형(Prototype)
Navigation.prototype = {
nextLink : function() {
console.log(this.el, '다음 링크 활성화');
},
prevLink : function() {
console.log(this.el, '이전 링크 활성화');
},
goToLink : function(num) {
console.log(num + '링크 활성화');
},
playRollingLinks : function() {
console.log('링크 롤링 시작');
},
stopRollingLinks : function() {
console.log('링크 롤링 중지');
}
};
// Navigation 인스턴스 객체 생성
var hNav = new Navigation('header nav');
var aNav = new Navigation('aside nav');
var mNav = new Navigation('main nav');
var fNav = new Navigation('footer nav');
// Navigation 인스턴스 객체 메소드 활용
hNav.nextLink();
mNav.prevLink();
Jaehee's WebClub
'JavaScript > JS 활용 & etc..' 카테고리의 다른 글
eval() 사용과 문제점 : #eval() is evil (5) | 2016.10.10 |
---|---|
객체와 배열을 활용하기 (1) | 2016.09.29 |
if, else 문 처리를 더 간결하게 표현하기 (0) | 2016.09.29 |
(function (window, document, undefined) {})(window, document); 의 진짜 의미 (0) | 2016.09.29 |
keyup 이벤트 알아보기 (0) | 2016.09.29 |