일반 [Copilot] ES6 모듈(module) 문법

황제낙엽 2024.06.21 06:58 조회 수 : 219

sitelink1  
sitelink2  
sitelink3  
sitelink4  
extra_vars4  
extra_vars5  
extra_vars6  

Vanilla JavaScript에서 외부 JS 파일에 클래스를 선언하고

이를 모듈로 로드하여 사용하는 방법은 ES6 모듈 문법을 사용하는 것입니다.

다음은 간단한 예제입니다:

 

1. 외부 JavaScript 파일(myModule.js)에 클래스를 선언합니다:

 

// myModule.js 파일

export class MyModule {

  constructor() {

    console.log('MyModule 클래스가 생성되었습니다!');

  }

 

  greet() {

    console.log('안녕하세요!');

  }

}

 

 

 

2. HTML 문서에서 <script> 태그의 type 속성을 "module"로 설정하여 외부 JavaScript 파일을 로드하고 클래스를 사용합니다:

<!DOCTYPE html>

<html lang="ko">

<head>

  <meta charset="UTF-8">

  <title>Module Example</title>

</head>

<body>

  <!-- 모듈 스크립트 로드 -->

  <script type="module">

    import { MyModule } from './myModule.js';

 

    // 클래스 인스턴스 생성 및 메서드 호출

    const myModuleInstance = new MyModule();

    myModuleInstance.greet();

  </script>

</body>

</html>

 

 

 

 

이 예제에서는 import 문을 사용하여 myModule.js 파일에서 MyModule 클래스를 가져옵니다.

그런 다음 클래스의 인스턴스를 생성하고 greet 메서드를 호출합니다.

type="module" 속성은 브라우저에게 해당 스크립트가 모듈임을 알려줍니다.

 

모듈 스크립트는 기본적으로 엄격 모드(strict mode)에서 실행되며, 모듈 파일은 CORS 정책을 따르기 때문에 동일 출처 정책을 준수해야 합니다.

또한, 모듈 스크립트는 비동기적으로 로드되므로, 페이지의 로드 시간에 영향을 주지 않습니다.

번호 제목 글쓴이 날짜 조회 수
114 [검토 완료] 디바이스 카메라로 촬영한 사진을 서버에 업로드하기 샘플 황제낙엽 2024.11.21 310
113 브라우저에서 이미지를 편집(crop 등) 할 수 있는 오픈소스 Cropper.js 황제낙엽 2024.11.16 341
112 DOMContentLoaded 이벤트와 window.onload 이벤트 황제낙엽 2024.07.15 231
111 [Copilot] Vanilla JavaScript에서 외부 스크립트 파일에 정의된 함수들을 로드 황제낙엽 2024.06.21 275
» [Copilot] ES6 모듈(module) 문법 황제낙엽 2024.06.21 219
109 현재 document 의 host 와 port 를 얻는 방법 황제낙엽 2023.10.03 670
108 (Bard) FileReader 로 여러개의 파일을 read 하는 법 file 황제낙엽 2023.08.23 469
107 navigator.mediaDevices 황제낙엽 2023.08.21 294
106 Barcode Detection API 황제낙엽 2023.08.06 513
105 체크박스에 체크된 항목 개수 구하기 황제낙엽 2023.06.10 497
104 배열에 대한 루프문 조회 (loop iterator) 황제낙엽 2023.03.01 560
103 (Copilot) 바닐라 스크립트가 뭐지? 황제낙엽 2023.02.24 264
102 문자열에서 역슬래시(backslash) 문자와 유니코드(Unicode)에 대한 고찰 file 황제낙엽 2021.06.03 494
101 자바스크립트(Javascript) escape, encodeURI, encodeURIComponent 인코딩 함수 황제낙엽 2021.04.27 446
100 자바스크립트 학습용 유튜브 강의 (드림코딩 by 엘리) 황제낙엽 2021.03.07 467
99 Early return, early exit - 스크립트 가독성 개선 팁 황제낙엽 2021.03.07 373
98 [GitHub] JavaScript Algorithms and Data Structures (알고리즘과 자료구조) file 황제낙엽 2021.03.01 320
97 비동기프로그래밍 - 콜백함수(Callback function) file 황제낙엽 2020.08.26 437
96 Strict 모드 황제낙엽 2020.08.23 342
95 경과 시간 구하기 황제낙엽 2019.10.04 1414