• node.js v12 이후부터는 ES Module이 지원
  • ES Module에서 import/export 문법을 사용 가능
  • node --version으로 버전 확인 (현재 버전은 v12.15.0)
  • package.json에 아래와 같이 추가하면 ES Module을 바로 사용
(...)
  "scripts": {
    "start": "node src esm src",
    "start:dev": "nodemon --watch src/ -r esm src/index.js"
  },
  "type": "module"
$ yarn add esm
exports.write = ctx => {
  const { title, body } = ctx.request.body;
  postId += 1;
  const post = { id: postId, title, body };
  posts.push(post);
  ctx.body = post;
}; 
  • export에 에러가 발생할텐데 .eslintrc.json에 아래와 같이 "sourceType": "module"을 추가
  "parserOptions": {
    "ecmaVersion": 2018,
    "sourceType": "module"
  },
  • 모든 .js의 파일에서 reuiqreimport/export로 변경
import Router from 'koa-router';
import posts from './posts';

const api = new Router();

api.use('/posts', posts.routes());

export default api;

react import package absolute path 하는 방법

Can't resolve module 이라는 에러가 난다면 상대경로가 아닌 절대경로로 하는게 좋다. 상대 경로로 할 경우에는 import module from '../../../과 같이 명시를 해줘야 하니... 절대 경로로 하는 방법은 아래와 같다.

Project의 ROOT (README.md를 보통 만드는)에 가서 .env의 파일을 만들고 NODE_PATH=src/ 다음과 같이 입력하면 src의 아래에 있는 pages, modules 등을 import Module from 'modules/modulename' 으로 입력하면 된다.

만약 적용이 안된다면 재시작을 해주면 정상적으로 반영된다.

+ Recent posts