개발자가 되고 싶은 사람

Angular기반 오픈소스 프로젝트를 이용한 사내 Private Explorer 구축 1

|

Intro

  • 사내 프로젝트를 위해 explorer 사이트를 열게 되었다. 1차적으로 private network를 기존 EOS Tracker에 있던 EOS Blockchain 설정만 바꾸어 먼저 오픈을 하게 되었다.
  • EOS Tracker는 EOSEssentials의 프로젝트 중 하나로 볼 수 있다.
  • EOS Tracker는 Real time block explorer for EOS Blockchain 로서, Oasisbloc Explorer는 이 프로젝트의 소스코드를 clone하여 작업을 진행하였다.
  • EOSEssentials의 다른 프로젝트를 확인하려면 이곳에서

Angular 기본 서칭

angular나 typescript에 대한 충분한 지식 없이 급하게 반영하다보니 코드를 보면 답답한 마음이 많이 들었던 작업이었다. 이제라도 angular에 대한 기본적인 것을 정리해보려고 한다.

  • 프로젝트는 angular 6를 사용했다.
  • angular 는 Typescript를 기반으로 개발이 되고, angular 어플리케이션은 typescript를 javascript로 변환해야 한다. (angular는 typescript 뿐만 아니라 javascript, dart로도 작성될 수 있지만, angular 공식 문서, 커뮤니티에서 가장 많이 활용되고 있는건 typescript라고 함.)
  • 또한 프로젝트가 의존하는 모듈들은 로드하는 html 파일의 script 태그를 작성해야 한다.
  • Angular CLI를 이용해 프로젝트를 생성하면, 의존 모듈의 설치는 기본 패키지 매니저인 npm으로 자동화되어 진행된다.
  • Angular cli의 빌드 기능은 의존성 관리를 위한 작업을 자동화 하여 진행한다.
  • aunular cli 빌드 기능은 내부적으로 모듈 번들러인 webpack을 이용하여 아래 작업을 자동으로 지원한다.
- TypeScript에서 javascript로의 트랜스파일링
- 디버깅 용도의 source map 파일 생성
- 의존 모듈과 HTML, CSS, 자바스크립트 번들링
- 코드의 문법 체크
- 코드의 규약 준수 여부 체크
- 불필요한 코드의 삭제 및 압축
- AoT 컴파일

Angular CLI란?

  • angular cli는 간단한 명령어를 사용해 angular 프로젝트 스캐폴딩(scaffolding)을 생성, 실행, 빌드할 수 있다.
  • angular의 다양한 구성 요소들을 선별적으로 추가할 수 있는 커맨드-라인(command line interface)이다.
  • 개발용 서버를 내장하고 있어서 간단히 프로젝트를 실행시켜서 동작을 확인할 수 있다. ( ng serve, ng serve & )
  • (심플하게 생각하면 프레임워크? angular cli는 프레임워크의 개발환경을 구축해준다~ )
  • angular cli는 angular 프로젝트 스캐폴딩을 간단한 명령어로 생성해주어 개발환경 구축에 소요되는 시간을 최소화할 뿐 아니라, 표준 스타일 가이드를 제공한다.

angula cli가 주로 지원해주는 기능

  • angular 프로젝트 생성
  • angular 프로젝트의 컴포넌트, 디렉티브, 파이프, 서비스, 클래스, 인터페이스 등의 구성 요소 추가
  • liveReload를 지원하는 내장 개발 서버를 사용한 angular 프로젝트 실행
  • unit/e2e(end-to-end) 테스트 환경 지원
  • 배포를 위한 angular 프로젝트 패키징

Angular 6 특징

  • 2018년 5월 출시
  • angular 5와 거의 유사, 5와 호환됨

Angular 5 에서 도입된 기능

  • HTTPClient API
  • Lambda지원
  • 여러 별칭을 사용해 구성 요소를 내보내어 마이그레이션 프로세스를 쉽게 수행 가능
  • 표준화를 위한 새로운 파이프 도입
  • 빌드 최적화 도입, build optimizer를 자동 지원
  • 향상된 컴파일러 적용

Angular 5 에서 추가된 기능

  • angular-cli 명령어 업데이트 : ex) ng-update
  • cdk 업데이트,
  • Angular Material Updated
  • 반응형 js 라이브러리인 RxJS 사용
  • Angular Element : 앵귤러 컴포넌트를 모든 html 페이지에서 사용할 수 있는 웹 컴포넌트로 게시할 수 있다. 앵귤러 요소 패키지를 사용하면 네이티브 맞춤 요소를 쉽게 만들 수 있다.
  • Tree on Service : 죽은 코드 제거 가능…

기타, Angular의 observable

  • observable은 angular 2가 나왔을때 소개된 것.
  • 옵저버블은 angular의 특정 기능이 아니고, es7 릴리스에 포함될 비동기 데이터를 관리하기 위한 새로운 표준이다.
  • angular는 이벤트 시스템과 http서비스에서 옵저버블을 광범위하게 사용한다.

Reference

  • https://jodu.tistory.com/38
  • https://poiemaweb.com/angular-cli
  • https://poiemaweb.com/angular-basics
  • https://han41858.tistory.com/45
  • https://steemit.com/javascript/@noreco/webpack
  • https://feel5ny.github.io/2018/03/25/angular_observable/

Comments