본문 바로가기

오픈소스/노드

[Node] React 정리(1) - 프로젝트 구성 방법 리액트로 프로젝트를 생성하여 개발하는 과정 중 리액트의 필수 문법 및 기초적인 부분, 심화 과정 등을 정리한 문서입니다. 정리한 부분에는 제가 이해하는 관점에서만 정리를 하였기 때문에 초점은 보여주는 형식이 아닌 제가 필요할 때 사용하려는 목적이 담겨져 있습니다. 이 문서는 어떠한 리액트의 이론을 다루는 것이 아닙니다. 또한 현재 정리하려는 것은 여러분이 필요한 JSX 부분이 아닐 수 있음을 알려드립니다. 본 과정에서는 차례대로 난이도가 증가하는 정리를 하지 않았습니다. 필요한 부분만을 사용하거나 훑어보는 용도로 사용하시기 바랍니다. # Contents 프로젝트 기본 설정 - index.html 사용 X 프로젝트 기본 설정 - index.html 사용 O # 프로젝트 기본 설정 - index.html 사.. 더보기
[Node] 05. Promise 그리고 Async/Await 본 문서는 Node.js 디자인 패턴 바이블 을 읽고 리뷰를 남기고 있습니다. 문고들은 이 책의 일부분을 인용한 것임을 밝힙니다. Node.js 에서 콜백은 비동기 프로그래밍의 기본적인 방식이지만 개발자 친화적인 것과는 거리가 멀어 보입니다. 실제로 이전 장에서 콜백을 사용하여 다양한 제어 프름을 구현하기 위한 기술을 배웠습니다. 그리고 그것들은 우리가 해결하려는 문제에 비해서 매우 복잡하고 장황하다고 볼 수 있었습니다. 특히, 우리가 작성하는 대부분의 제어 흐름 구조는 순차적인 함수의 실행인데 이에 익숙하지 않은 개발자들에게 콜백 지옥이라는 문제를 일으키게 만듭니다. 게다가, 제대로 구현된 경우라 해도 콜백을 통한 순차적인 실행 흐름은 불필요하게 복잡하고 오류가 발생하기 쉽습니다. 또한 콜백을 사용한 .. 더보기
[Node] React regeneratorRuntime is not defined 에러 해결 - TroubleShooting 리액트 프로젝트를 진행 하던 도중 regeneratorRuntime is not defined 오류가 발생하였고 이로 인해 웹팩 전체 프로젝트가 렌더링 되지 않았습니다. es6 이상의 문법들이 es5로 문법 변환해주는 babel 을 이용하여 프로젝트가 구성 되어 있었는데 async/await 문법을 해당 regenerator를 제공하지 않아서 발생한 에러입니다. 해결 방안은 바벨의 플러그인을 설치 한 후 환경 설정 파일에 플러그인을 등록하는 것입니다. # Contents 해결 방안 # 해결 방안 먼저 아래 명령어를 이용하여 바벨 플러그인을 설치하도록 합니다. npm install @babel/plugin-transform-runtime -D 바벨 설정 파일에 아래 코드를 넣습니다. "plugins": [.. 더보기
[Node] Babel Preset, Babelrc 리액트를 공부하는 도중에 설치된 Babel 은 리액트 프로젝트를 이용할 때 자연스럽게 라이브러리가 추가되었습니다. 이 라이브러리가 무엇인지 부터 파악하는 것이 급했었던 저는 Babel은 es6 버전을 사용하는 리액트의 경우 브라우저 별로 지원하지 않는 함수들이 존재하기 때문 에 Babel을 사용한다고 파악하였습니다. 그러면 Babel을 적용하는 방법 이 궁금했었습니다. 그래서 간단하게 Babel을 파악하고 리액트에서 사용했던 Babel-preset-env와 babelrc에 대해 간략하게 소개하도록 하겠습니다. 본 문서는 웹팩을 이용한 Babel 사용법을 나타내고 있습니다. # Contents 바벨 적용 Babel-preset-env 및 babelrc # 바벨 적용 바벨을 웹팩으로 적용시키는 방법은 아주 .. 더보기
[Node] React 프로젝트를 직접 만들어보기 with Babel, Webpack 리액트는 Facebook에서 만들고 유지 관리하는 인기있는 JavaScript 라이브러리 입니다. 리액트는 웹 애플리케이션에서 뷰 레이어를 만들기 위한 포괄적인 도구들을 제공하는데 중점 을 둡니다. 리액트는 컴포넌트 개념에 초점을 맞추어 뷰의 추상화를 제공합니다. 컴포넌트는 버튼, 입력 폼, HTML div 와 같은 간단한 컨테이너 혹은 사용자 인터페이스의 다른 요소 일 수 있습니다. 개념은 특정 책임이 있는 재사용성이 높은 컴포넌트를 정의하고 구성하여 애플리케이션의 사용자 인터페이스를 구성할 수 있어야 한다는 것입니다. 이러한 리액트를 사용하기 위해서는 프로젝트를 생성하는 것이 당연지사입니다. 맨 처음 리액트 프로젝트를 생성할 때 많은 사람들은 아래의 명령어를 입력하여 간단하게 프로젝트를 생성하곤 합니.. 더보기
[Node] Webpack 쓸만한 Plugins 웹팩에서 쓸만한 플러그인을 정리해보았습니다. 웹팩을 사용하는 방법을 이해하고, config 파일을 수정하는 방법에 대한 이해가 필요합니다. 현 문서는 플러그인의 종류와 사용방법에만 알려드릴 뿐 웹팩에 사용법을 정의하지 않았습니다. 웹팩에 사용법은 다른 문서를 참고해주시기 바랍니다. 이 문서는 항시 업데이트 할 수 있음을 알려드립니다. # Contents 변수 정의 및 사용 - DefinePlugin 환경변수 정의 및 사용 - EnvironmentPlugin 최적화 - TerserPlugin # 변수 정의 및 사용 웹팩에서의 변수를 선언하여 선언된 변수를 의존된 자바스크립트 코드 에서 사용할 수 있습니다. 웹팩에서 제공하는 DefinePlugin 은 모든 자바스크립트 코드에서 접근 가능한 변수 를 선언하기.. 더보기
[Node] Webpack 설치 및 사용법 JavaScript는 웹 개발자에게 브라우저에서 직접 코드를 실행하고 동적인 대화형 웹 사이트를 구축할 수 있는 능력을 제공한다는 목표 로 탄생하였습니다. 지금까지 JavaScript는 많은 성장을 하였습니다. 처음 JavaScript가 매우 간단하고 제한된 언어 였다면 오늘날에는 거의 모든 종류의 애플리케이션을 빌드하기 위해 브라우저 외부에서도 사용할 수 있는 완전한 범용 언어 로 간주될 수 있습니다. 실제로 JavaScript는 이제 프론트엔드 애플리케이션, 엡 서버 및 모바일 애플리케이션은 물론 웨어러블 장치, 온도 조절기, 비행드론과 같은 임베디드 장치를 지원하고 있습니다. 새로운 추세에 JavaScript 개발자들은 동일한 프로젝트의 여러 환경에서 코드를 재사용하고 단순화 시킬 필요 가 있다고 .. 더보기
[Node] PM2 설치 및 사용법 PM2 또는 Process Manager 2는 개발자와 Devops가 프로덕션 환경에서 Node.js 애플리케이션을 관리하는 데 도움 이 되는 오픈 소스 프로덕션 Node.js 프로세스 관리자입니다. Supervisord, Forever, Systemd 와 같은 다른 프로세스 관리자와 비교하여 PM2의 일부 주요 기능은 자동 애플리케이션 로드 밸런싱, 선언적 애플리케이션 구성, 배포 시스템 및 모니터링 입니다. 기존에 클러스터 모드 및 오류로 인한 프로세스 종료 현상 등 개발자가 인지하지 못한 상황에서 간단한 설정으로 이러한 문제들을 해결할 수 있는 Node 의 인기 라이브러리 중 하나입니다. 그러면 실무에서 필요로 하는 최소한의 정보들을 알아보고 적용해보도록 합시다. # Contents PM2 설치 P.. 더보기