GithubHelp home page GithubHelp logo

atjsh / nestjs-esm Goto Github PK

View Code? Open in Web Editor NEW
0.0 1.0 0.0 71.92 MB

A aample NestJS Project with ESM module setting - ESM 모듈 설정을 사용하는 NestJS 샘플 프로젝트

JavaScript 23.26% TypeScript 76.74%

nestjs-esm's Introduction

NestJS Project with ESM Module setting

With this repository's configuration, transpiled source codes will be in ESM format import syntax.

이 리포지토리의 설정들을 사용하면, 트랜스파일된 소스코드들은 ESM 형식의 import 구문을 사용하게 될 것이다.

Changed Settings - 바뀐 설정들

tsconfig.json

{
  "compilerOptions": {
+   "module": "node16",
-   "module": "commonjs",
...

package.json

{
  "name": "nest-esm",
+ "type": "module",
  "scripts": {
...

src/app.module.ts and other Typescript source files - src/app.module.ts 와 다른 타입스크립트 파일들

Source code's import syntax is changed. Local typescript files should be imported with .js extension.

소스코드의 import 구문이 바뀌었다. .js 확장자를 붙여서 import 해야 한다.

source (출처): Typescript Blog

import { Module } from '@nestjs/common';
+ import { AppController } from './app.controller.js';
+ import { AppService } from './app.service.js';
- import { AppController } from './app.controller';
- import { AppService } from './app.service';

@Module({
  imports: [],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule {}

Additional Information - 추가 정보

  • This repository uses Yarn Berry (v3) as package manager. - 이 리포지토리는 패키지 매니저로 Yarn Berry (v3) 를 사용한다.
  • Yarn Berry's Plug'n'Play is enabled in this repository. - 이 리포지토리에서는 Yarn Berry의 Plug'n'Play 가 활성화되어 있다.

nestjs-esm's People

Contributors

atjsh avatar

Watchers

 avatar

nestjs-esm's Issues

파일 improt 시 .js 확장자를 안 써도 되도록 개선하기

import { Module } from '@nestjs/common';
+ import { AppController } from './app.controller.js';
+ import { AppService } from './app.service.js';
- import { AppController } from './app.controller';
- import { AppService } from './app.service';

@Module({
  imports: [],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule {}

현재는 위처럼 .js 확장자가 뒤에 붙어야 import를 할 수 있음.

개인적으로 익숙한 문법이 아니라서, CommonJS 쓸 때 썼던 것처럼 .js 없이도 import가 가능하다면 더 좋을 것 같음.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.