일반 [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 정책을 따르기 때문에 동일 출처 정책을 준수해야 합니다.

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

번호 제목 글쓴이 날짜 조회 수
246 [Gemini] ajax 와 fetch 의 차이 황제낙엽 2025.01.04 205
245 [검토 완료] 디바이스 카메라로 촬영한 사진을 서버에 업로드하기 샘플 황제낙엽 2024.11.21 310
244 브라우저에서 이미지를 편집(crop 등) 할 수 있는 오픈소스 Cropper.js 황제낙엽 2024.11.16 341
243 [ChatGPT] json data 의 정렬 [1] 황제낙엽 2024.07.23 204
242 DOMContentLoaded 이벤트와 window.onload 이벤트 황제낙엽 2024.07.15 231
241 fetch() 사용 예제들 황제낙엽 2024.07.09 263
240 [Copilot] Vanilla JavaScript에서 외부 스크립트 파일에 정의된 함수들을 로드 황제낙엽 2024.06.21 275
» [Copilot] ES6 모듈(module) 문법 황제낙엽 2024.06.21 219
238 [Copilot] JSON 객체 내부 데이터를 순회하면서 조회하는 코드 황제낙엽 2024.06.02 213
237 [Copilot] JavaScript로 서버에 특정 값을 POST 방식으로 전달하고 응답을 기다리지 않고 바로 종료 황제낙엽 2024.05.31 394
236 json 데이터 내의 변수명에 prefix 로 type 표현하기 황제낙엽 2024.04.15 211
235 fetch() 함수 사용 예제 file 황제낙엽 2023.11.23 435
234 현재 document 의 host 와 port 를 얻는 방법 황제낙엽 2023.10.03 670
233 (Bard) FileReader 로 여러개의 파일을 read 하는 법 file 황제낙엽 2023.08.23 469
232 How to build a file upload service with vanilla JavaScript file 황제낙엽 2023.08.22 287
231 (Bard) JavaScript로 JSON 배열을 작성하는 방법 황제낙엽 2023.08.21 235
230 모바일 브라우저에서 file input element 를 이용하여 여러장의 이미지를 서버에 전송하려 할때 [1] 황제낙엽 2023.08.21 318
229 navigator.mediaDevices 황제낙엽 2023.08.21 294
228 Barcode Detection API 황제낙엽 2023.08.06 513
227 정규식을 이용한 이메일 검증 스크립트 file 황제낙엽 2023.06.25 199