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.
   }
   
);

모듈 로딩