본문 바로가기
webpack

13. 효율적인 코드 분할 - 2

by leo2114 2023. 12. 24.
반응형

동적 임포트 활용

JavaScript의 모듈 시스템은 코드의 재사용성과 유지보수성을 향상시키는데 큰 기여를 하고 있습니다. ES6부터 지원되는 동적 임포트는 특히 런타임에서 모듈을 필요에 따라 동적으로 로딩하는 데 사용됩니다. 이 기능은 코드 분할(Code Splitting)과 함께 사용되어 대규모 애플리케이션에서 필요한 모듈만 로딩하여 성능을 향상시킬 수 있습니다.

1. 동적 임포트의 개요

동적 임포트는 import() 함수를 사용하여 모듈을 비동기적으로 로딩하는 것을 말합니다. 이는 런타임 시에 모듈이 필요한 순간에만 로딩되게 할 수 있습니다. 기존의 정적 임포트는 빌드 타임에 모든 모듈을 로딩하는 반면, 동적 임포트는 런타임에 필요한 모듈만 로딩되므로 초기 로딩 속도를 향상시키는 데 기여합니다.

// 정적 임포트
import { myFunction } from './my-module';

// 동적 임포트
import('./my-module')
  .then((module) => {
    // 모듈 사용
    module.myFunction();
  })
  .catch((error) => {
    console.error('모듈 로딩 실패', error);
  });

2. 코드 분할과의 결합

동적 임포트는 주로 코드 분할과 결합하여 사용됩니다. 특히 대규모 애플리케이션에서 여러 모듈을 번들로 묶지 않고, 필요한 모듈만 필요한 시점에 로딩하여 성능을 최적화할 수 있습니다.

// 코드 분할과 동적 임포트
const button = document.getElementById('my-button');

button.addEventListener('click', () => {
  import('./modules/my-modal')
    .then((module) => {
      // 모듈 사용
      module.openModal();
    })
    .catch((error) => {
      console.error('모듈 로딩 실패', error);
    });
});

3. 주의사항

3.1. 에러 핸들링

동적 임포트 시에는 catch 블록을 통해 모듈 로딩 중 발생한 에러를 처리해야 합니다. 이를 통해 사용자 경험을 향상시킬 수 있습니다.

3.2. Webpack 설정

Webpack과 같은 번들러를 사용할 때는 동적 임포트를 활용하기 위해 추가적인 설정이 필요할 수 있습니다. 번들러의 문서를 참고하여 설정을 확인하고 적절히 구성해야 합니다.

4. 동적 임포트 활용 시나리오

4.1. 라우팅

웹 애플리케이션의 특정 페이지로 이동할 때 해당 페이지에 필요한 모듈을 동적으로 로딩하여 초기 로딩 속도를 최적화할 수 있습니다.

// 라우팅 시 동적 임포트 활용
const loadPage = (pageName) => {
  import(`./pages/${pageName}`)
    .then((page) => {
      // 페이지 로딩
      page.load();
    })
    .catch((error) => {
      console.error('페이지 로딩 실패', error);
    });
};

4.2. 조건부 로딩

특정 조건이 충족될 때에만 모듈을 로딩할 수 있습니다. 이는 사용자가 특정 기능을 요청할 때 필요한 모듈만 로딩하여 효율적으로 자원을 관리할 수 있습니다.

// 조건부 동적 임포트
if (someCondition) {
  import('./feature-module')
    .then((module) => {
      // 모듈 사용
      module.doSomething();
    })
    .catch((error) => {
      console.error('모듈 로딩 실패', error);
    });
}

 

동적 임포트는 모듈을 런타임에서 효율적으로 관리할 수 있는 강력한 기능을 제공합니다. 코드 분할과 결합하여 사용하면 대규모 웹 애플리케이션의 성능을 향상시킬 수 있습니다.

반응형