RequireJS-플러그인

RequireJS에는 다양한 유형의 리소스를 종속성으로로드 할 수있는 작은 플러그인 세트가 포함되어 있습니다. 다음은 RequireJS에서 사용 가능한 플러그인 목록입니다.

  • text
  • domReady
  • i18n
  • CSS 로딩

본문

텍스트 플러그인은 주로 자바 스크립트 파일의 HTML 콘텐츠를 삽입에 사용되는 비동기 로딩 텍스트 기반 리소스에 사용됩니다. 텍스트 를 사용할 때로드 할 수 있습니다 ! 필수 또는 정의 모듈 호출의 접두어를 사용하고 플러그인에 파일 확장자를 전달하십시오. 일반 모듈로드와 비교하여 텍스트 플러그인은 XHR을 사용하여 모듈을로드하며 코드를 헤더에 추가하지 않습니다.script 꼬리표.

텍스트 파일 리소스는 다음과 같이 코드에 종속성으로 포함될 수 있습니다.

require(["mymodule", "text!mymodule.html", "text!mymodule.css"],
   
   function(mymodule, html, css) {
      //the html and css variables will be the text
      //of the mymodule.html file and mymodule.css files respectively
   }
);

domReady

RequireJS는 DOM이 준비되기 전에 스크립트를로드하는 데 사용할 수 있으며 개발자는 스크립트가 완전히로드 될 때만 DOM과 상호 작용할 수 있습니다. 때로는 DOM이 준비되기 전에 스크립트를로드 할 수 있습니다. 그래서이 문제를 극복하기 위해, RequireJS라는 현대적인 접근 방식 제공 DOMContentLoaded의 DOM이 준비되면 domReady 함수를 호출 이벤트를.

require(['domReady'], function(domReady) {
   
   domReady(function() {
      //the domReady function is called when DOM is ready 
      //which is safe to manipulate DOM nodes in this function
   });
});

i18n

제공하는 여러 로케일과 함께 사용할 수 있습니다. i18n모듈 또는 종속성이 "i18n!"을 지정할 때 자동으로로드되는 번들 지원 접두사. 이를 사용하려면 다운로드하여 기본 JavaScript 파일이있는 동일한 디렉토리에 넣으십시오. 이 플러그인을 "nls"라는 디렉토리에 배치하여 현지화 파일을 찾으십시오.

예를 들어, 우리는 하나 개의 js 파일이라는 있다고 가정 country.js 같은 디렉토리에 다음과 같은 내용과 장소를 가진 mydirectory / NLS / country.js을 -

define({
   
   "root": {
      "india": "india",
      "australia": "australia",
      "england": "england"
   }
});

fr-fr 로케일 을 사용하여 파일에 특정 번역을 추가 할 수 있으며 위 코드는 다음과 같이 변경됩니다.

define({
   
   "root": {
      "title": "title",
      "header": "header",
      "description": "description"
   },
   
   "es-es": true
});

다음으로 mydirectory / nls / es-es / country.js 에 다음 내용으로 파일을 지정하십시오.

define({
   
   "root": {
      "title": "título",
      "header": "cabecera",
      "description": "descripción"
   },
   
   "es-es": true
});

아래와 같이 main.js 파일 의 모듈 구성을 사용하여 플러그인에 전달하여 로케일을 설정할 수 있습니다.

requirejs.config({
   
   config: {
      //set the config for the i18n plugin
      
      i18n: {
         locale: 'es-es'
      }
      
   }
});

RequireJS를 사용한 CSS 로딩

일부 플러그인을 사용하여 CSS 파일을로드하기 위해 헤더 링크에 추가하여 CSS 파일을로드 할 수 있습니다.

CSS는 아래와 같이 자신의 기능을 사용하여로드 할 수 있습니다.

function myCss(url) {
   var mylink = document.createElement("mylink");
   mylink.type = "text/css";
   mylink.rel = "stylesheet";
   mylink.href = url;
   document.getElementsByTagName("head")[0].appendChild(mylink);
}