RequireJS-AMD 모듈
RequireJS의 모듈은 범위가 지정된 개체이며 전역 네임 스페이스에서 사용할 수 없습니다. 따라서 글로벌 네임 스페이스는 오염되지 않습니다. RequireJS 구문을 사용하면 종속성 순서를 추적 할 필요없이 모듈을 더 빠르게로드 할 수 있습니다. 동일한 페이지에서 동일한 모듈의 여러 버전을로드 할 수 있습니다.
모듈 정의
모듈은 define()함수; 모듈을로드하는 데에도 동일한 기능이 사용됩니다.
간단한 이름 / 값 쌍
모듈이 이름과 값 쌍의 모음 인 경우 다음 구문을 사용할 수 있습니다.
define({
state: "karnataka",
city: "bangalore"
});
함수 정의
모듈은 종속성없이 프레임 워크에 대한 함수를 사용할 수도 있습니다. 이것은 다음 구문을 사용하여 수행 할 수 있습니다-
define(function () {
//Do setup work here
return {
state: "karnataka",
city: "bangalore"
}
});
종속성이있는 함수 정의
모듈에 종속성이있는 경우 첫 번째 인수 (종속성 이름 배열), 두 번째 인수 (함수 정의) 및 모듈을 정의하는 반환 객체의 위치는 다음 구문에 표시됩니다.
define(["./mnc", "./startup"],
function(mnc, startup) {
return {
state: "karnataka",
city: "bangalore",
addCompany: function() {
mnc.decrement(this);
startup.add(this);
}
}
}
);
모듈을 함수로 정의
모듈이 객체 만 반환하는 것은 필수가 아니며 함수의 유효한 값도 반환 될 수 있습니다. 다음 구문은 모듈을 함수로 정의하는 데 사용됩니다-
define(["./mnc", "./startup"],
function(mnc, startup) {
return function(title) {
return title ? (window.title = title) :
startup.storeName + ' ' + mnc.name;
}
}
);
이름으로 모듈 정의
어떤 경우에는 모듈의 이름을 첫 번째 인수로 포함해야 할 수 있습니다. define(). 이것은 다음 구문을 사용하여 수행 할 수 있습니다-
define("js2/title",
["js1/mnc", "js1/startup"],
function(mnc, startup) {
//Define js2/title object in here.
}
);
모듈 로딩