Angular 2-퀵 가이드

Angular JS는 JavaScript를 기반으로 구축 된 오픈 소스 프레임 워크입니다. Google 개발자가 만들었습니다. 이 프레임 워크는 단일 페이지 애플리케이션으로 작업하는 동안 발생하는 장애물을 극복하는 데 사용되었습니다. 또한 프레임 워크를 구축하는 동안 테스트가 핵심 요소로 간주되었습니다. 프레임 워크를 쉽게 테스트 할 수 있습니다. 프레임 워크의 초기 릴리스는 2010 년 10 월이었습니다.

Angular 2의 특징

다음은 Angular 2의 주요 기능입니다-

  • Components− 이전 버전의 Angular는 컨트롤러에 중점을 두었지만 이제는 컨트롤러보다 구성 요소를 사용하도록 포커스를 변경했습니다. 구성 요소는 응용 프로그램을 여러 모듈로 빌드하는 데 도움이됩니다. 이는 일정 기간 동안 애플리케이션을 더 잘 유지하는 데 도움이됩니다.

  • TypeScript− Angular의 최신 버전은 TypeScript를 기반으로합니다. 이것은 JavaScript의 상위 집합이며 Microsoft에서 유지 관리합니다.

  • Services− 서비스는 애플리케이션의 여러 구성 요소에서 공유 할 수있는 코드 세트입니다. 예를 들어 데이터베이스에서 데이터를 선택하는 데이터 구성 요소가있는 경우 여러 응용 프로그램에서 사용할 수있는 공유 서비스로 사용할 수 있습니다.

또한 Angular 2는 더 나은 이벤트 처리 기능, 강력한 템플릿 및 모바일 장치에 대한 더 나은 지원을 제공합니다.

Angular 2의 구성 요소

Angular 2에는 다음과 같은 구성 요소가 있습니다.

  • Modules− 이것은 응용 프로그램을 논리적 코드 조각으로 나누는 데 사용됩니다. 각 코드 또는 모듈은 단일 작업을 수행하도록 설계되었습니다.

  • Component − 모듈을 하나로 모으는 데 사용할 수 있습니다.

  • Templates − Angular JS 애플리케이션의 뷰를 정의하는 데 사용됩니다.

  • Metadata − Angular JS 클래스에 더 많은 데이터를 추가하는 데 사용할 수 있습니다.

  • Service − 전체 응용 프로그램에서 공유 할 수있는 구성 요소를 만드는 데 사용됩니다.

이 튜토리얼의 후속 장에서 이러한 모든 구성 요소에 대해 자세히 설명합니다.

Angular의 공식 사이트는 https://angular.io/ 이 사이트에는 Angular 2에 대한 모든 정보와 문서가 있습니다.

Angular 2 작업을 시작하려면 다음 주요 구성 요소를 설치해야합니다.

  • Npm− 이것은 오픈 소스 리포지토리로 작업하는 데 사용되는 노드 패키지 관리자로 알려져 있습니다. 프레임 워크로서의 Angular JS는 다른 컴포넌트에 의존합니다. 과npm 이러한 종속성을 다운로드하고 프로젝트에 연결하는 데 사용할 수 있습니다.

  • Git − 이것은 샘플 응용 프로그램을 가져 오는 데 사용할 수있는 소스 코드 소프트웨어입니다. github 각도 사이트.

  • Editor− Visual Studio 코드, WebStorm 등 Angular JS 개발에 사용할 수있는 편집기가 많이 있습니다. 이 자습서에서는 Microsoft에서 무료로 제공하는 Visual Studio 코드를 사용합니다.

npm 설치

이제 npm을 설치하는 단계를 살펴 보겠습니다. npm의 공식 사이트는https://www.npmjs.com/

Step 1 − 사이트의 "npm 시작하기"섹션으로 이동합니다.

Step 2− 다음 화면에서 운영 체제에 따라 다운로드 할 설치 프로그램을 선택합니다. 이 연습의 목적을 위해 Windows 64 비트 버전을 다운로드하십시오.

Step 3− 설치 프로그램을 시작합니다. 초기 화면에서 다음 버튼을 클릭합니다.

Step 4 − 다음 화면에서 라이선스 계약에 동의하고 다음 버튼을 클릭합니다.

Step 5 − 다음 화면에서 설치할 대상 폴더를 선택하고 다음 버튼을 클릭합니다.

Step 6− 다음 화면에서 구성 요소를 선택하고 다음 버튼을 클릭합니다. 기본 설치를 위해 모든 구성 요소를 수락 할 수 있습니다.

Step 7 − 다음 화면에서 설치 버튼을 클릭합니다.

Step 8 − 설치가 완료되면 마침 버튼을 클릭하십시오.

Step 9− 설치를 확인하기 위해 명령 프롬프트에서 npm 버전 명령을 실행할 수 있습니다. 다음 스크린 샷과 같이 npm의 버전 번호를 얻을 수 있습니다.

Visual Studio Code 설치

다음은 Visual Studio Code의 기능입니다-

  • Visual Studio의 실제 버전과 비교할 때 가벼운 편집기.

  • Clojure, Java, Objective-C 및 기타 여러 언어와 같은 코딩 언어에 사용할 수 있습니다.

  • 내장 Git 확장.

  • 기본 제공 IntelliSense 기능.

  • 개발을위한 더 많은 확장.

Visual Studio 코드의 공식 사이트는 https://code.visualstudio.com/

Step 1− 다운로드가 완료된 후 설치 단계를 따르십시오. 초기 화면에서 다음 버튼을 클릭합니다.

Step 2 − 다음 화면에서 사용권 계약에 동의하고 다음 버튼을 클릭합니다.

Step 3 − 다음 화면에서 설치할 위치를 선택하고 다음 버튼을 클릭합니다.

Step 4 − 프로그램 바로 가기의 이름을 선택하고 다음 버튼을 클릭합니다.

Step 5 − 기본 설정을 수락하고 다음 버튼을 클릭합니다.

Step 6 − 다음 화면에서 설치 버튼을 클릭합니다.

Step 7 − 최종 화면에서 Finish 버튼을 클릭하여 Visual Studio Code를 시작합니다.

Git 설치

Git의 주요 기능 중 일부는 다음과 같습니다.

  • 코드의 쉬운 분기 및 병합.
  • Git 내에서 코드 흐름에 많은 기술을 사용하도록 제공합니다.
  • Git은 다른 SCM 도구와 비교할 때 매우 빠릅니다.
  • 더 나은 데이터 보증을 제공합니다.
  • 무료 및 오픈 소스.

Git의 공식 사이트는 https://git-scm.com/

Step 1− 다운로드가 완료된 후 설치 단계를 따르십시오. 초기 화면에서 다음 버튼을 클릭합니다.

Step 2− 설치해야하는 구성 요소를 선택합니다. 기본 구성 요소를 사용할 수 있습니다.

Step 3 − 다음 단계에서 프로그램 바로 가기 이름을 선택하고 다음 버튼을 클릭합니다.

Step 4 − 기본 SSH 실행 파일을 수락하고 다음 버튼을 클릭합니다.

Step 5 − "Checkout Windows style, commit Unix style endings"의 기본 설정을 수락하고 Next 버튼을 클릭합니다.

Step 6 − 이제 터미널 에뮬레이터의 기본 설정을 수락하고 다음 버튼을 클릭합니다.

Step 7 − 기본 설정을 수락하고 다음 버튼을 클릭합니다.

Step 8 − 실험 옵션을 건너 뛰고 설치 버튼을 클릭 할 수 있습니다.

Step 9 − 마지막 화면에서 마침 버튼을 클릭하여 설치를 완료합니다.

첫 번째 Angular JS 애플리케이션을 시작하는 방법에는 여러 가지가 있습니다.

  • 한 가지 방법은 가장 어렵고 선호되는 방법이 아닌 모든 것을 처음부터 시작하는 것입니다. 많은 종속성으로 인해이 설정을 얻는 것이 어려워집니다.

  • 또 다른 방법은 Angular Github에서 빠른 시작을 사용하는 것입니다. 여기에는 시작하는 데 필요한 코드가 포함되어 있습니다. 이것은 일반적으로 모든 개발자가 선택하는 것이며 Hello World 애플리케이션에 대해 표시 할 것입니다.

  • 마지막 방법은 Angular CLI를 사용하는 것입니다. 이에 대해서는 별도의 장에서 자세히 설명합니다.

다음은 github를 통해 샘플 애플리케이션을 시작하고 실행하는 단계입니다.

Step 1 − github URL로 이동- https://github.com/angular/quickstart

Step 2− 명령 프롬프트로 이동하여 프로젝트 디렉토리를 생성하십시오. 빈 디렉터리 일 수 있습니다. 이 예에서는 Project라는 디렉토리를 만들었습니다.

Step 3− 다음으로, 명령 프롬프트에서이 디렉토리로 이동하고 다음 명령을 실행하여 로컬 시스템에서 github 저장소를 복제합니다. 다음 명령을 실행하여이를 수행 할 수 있습니다.

git clone https://github.com/angular/quickstart Demo

그러면 로컬 컴퓨터에 샘플 Angular JS 애플리케이션이 생성됩니다.

Step 4 − Visual Studio 코드에서 코드를 엽니 다.

Step 5 − 명령 프롬프트와 프로젝트 폴더로 다시 이동하여 다음 명령을 실행합니다. −

npm install

그러면 Angular JS 애플리케이션이 작동하는 데 필요한 모든 필수 패키지가 설치됩니다.

완료되면 모든 종속성이 설치된 트리 구조가 표시됩니다.

Step 6− Demo → src → app → app.component.ts 폴더로 이동합니다. 다음 코드 줄 찾기-

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: `<h1>Hello {{name}}</h1>`,
})
export class AppComponent  { name = 'Angular'; }

그리고 아래와 같이 Angular 키워드를 World로 바꾸십시오.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: `<h1>Hello {{name}}</h1>`,
})
export class AppComponent  { name = 'World'; }

Angular 2 응용 프로그램에 대한 프로젝트 생성의 일부로 생성되는 다른 파일이 있습니다. 현재 다른 코드 파일은 Angular 2 애플리케이션의 일부로 포함되어 있으며 Hello World 애플리케이션을 위해 변경할 필요가 없기 때문에 다른 코드 파일에 대해 신경 쓸 필요가 없습니다.

다음 장에서이 파일에 대해 자세히 설명합니다.

Note − Visual Studio Code는 모든 파일을 자동으로 컴파일하고 모든 typescript 파일에 대한 JavaScript 파일을 생성합니다.

Step 7− 이제 명령 프롬프트로 이동하여 npm start 명령을 실행하십시오. 그러면 노드 패키지 관리자가 라이트 웹 서버를 시작하고 Angular 애플리케이션을 시작합니다.

이제 Angular JS 애플리케이션이 브라우저에서 시작되고 다음 스크린 샷과 같이 브라우저에 "Hello World"가 표시됩니다.

전개

이 항목은 위의 Hello world 애플리케이션 배포에 중점을 둡니다. Angular JS 애플리케이션이기 때문에 모든 플랫폼에 배포 할 수 있습니다. 모든 플랫폼에서 개발할 수 있습니다.

이 경우 Visual Studio 코드를 사용하는 Windows에 있습니다. 이제 두 가지 배포 옵션을 살펴 보겠습니다.

Windows의 NGNIX 서버에 배포

Angular JS 애플리케이션을 호스팅하기 위해 모든 플랫폼에서 모든 웹 서버를 사용할 수 있습니다. 여기서는 인기있는 웹 서버 인 NGNIX를 예로 들어 보겠습니다.

Step 1 − 다음 URL에서 NGNIX 웹 서버를 다운로드하십시오. http://nginx.org/en/download.html

Step 2− 다운로드 한 zip 파일을 추출한 후 nginx exe 구성 요소를 실행하면 웹 서버가 백그라운드에서 실행됩니다. 그러면 URL의 홈 페이지로 이동할 수 있습니다.http://localhost

Step 3 − Windows 탐색기에서 Angular JS 프로젝트 폴더로 이동합니다.

Step 4 − Project → Demo → node-modules 폴더를 복사합니다.

Step 5 − 프로젝트 → 데모 → src 폴더의 모든 내용을 복사합니다.

Step 6 − 모든 콘텐츠를 nginx / html 폴더에 복사합니다.

이제 URL로 이동- http://localhost, 실제로 다음 스크린 샷과 같이 hello world 애플리케이션이 표시됩니다.

Ubuntu에서 설정

이제 동일한 hello world 애플리케이션을 Ubuntu 서버에 호스팅하는 방법을 살펴 보겠습니다.

Step 1 − Ubuntu 서버에서 다음 명령을 실행하여 nginx를 설치합니다.

apt-get update

위의 명령은 시스템의 모든 패키지가 최신 상태인지 확인합니다.

완료되면 시스템이 최신 상태 여야합니다.

Step 2 − 이제 다음 명령을 실행하여 Ubuntu 서버에 GIT를 설치합니다.

sudo apt-get install git

완료되면 GIT가 시스템에 설치됩니다.

Step 3 − 확인하려면 git 버전, 다음 명령을 실행하십시오.

sudo git –version

Step 4 − 설치 npmUbuntu의 노드 패키지 관리자입니다. 이렇게하려면 다음 명령을 실행하십시오.

sudo apt-get install npm

완료되면 npm 시스템에 설치됩니다.

Step 5 − 확인하려면 npm 버전, 다음 명령을 실행하십시오.

sudo npm -version

Step 6 − 다음으로 설치 nodejs. 이것은 다음 명령을 통해 수행 할 수 있습니다.

sudo npm install nodejs

Step 7 − Node.js의 버전을 확인하려면 다음 명령을 실행하십시오.

sudo nodejs –version

Step 8 − 다음 git 명령을 사용하여 프로젝트 폴더를 생성하고 github starter 프로젝트를 다운로드합니다.

git clone https://github.com/angular/quickstart Demo

그러면 로컬 시스템의 모든 파일이 다운로드됩니다.

폴더를 탐색하여 github에서 파일이 성공적으로 다운로드되었는지 확인할 수 있습니다.

Step 9 − 다음으로 npm에 대해 다음 명령을 실행합니다.

npm install

Angular JS 애플리케이션이 작동하는 데 필요한 모든 필수 패키지가 설치됩니다.

완료되면 시스템에 설치된 모든 종속성을 볼 수 있습니다.

Step 10− Demo → src → app → app.component.ts 폴더로 이동합니다. 필요한 경우 vim 편집기를 사용하십시오. 다음 코드 줄 찾기-

import { Component } from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   template: '<h1>Hello {{name}}</h1>'; 
}) 
export class AppComponent { name = 'Angular'; }

그리고 다음 코드와 같이 Angular 키워드를 World로 바꿉니다.

import { Component } from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   template: '<h1>Hello {{name}}</h1>'; 
}) 
export class AppComponent { name = 'World'; }

Angular 2 응용 프로그램에 대한 프로젝트 생성의 일부로 생성되는 다른 파일이 있습니다. 현재 다른 코드 파일은 Angular 2 애플리케이션의 일부로 포함되어 있고 Hello World 애플리케이션을 위해 변경할 필요가 없기 때문에 다른 코드 파일에 대해 신경 쓸 필요가 없습니다.

다음 장에서이 파일에 대해 자세히 설명합니다.

Step 11− 다음으로 Angular 2 응용 프로그램을 실행할 수있는 라이트 서버를 설치합니다. 다음 명령을 실행하여이를 수행 할 수 있습니다.

sudo npm install –save-dev lite-server

완료되면 완료 상태가 표시됩니다. 경고에 대해 걱정할 필요가 없습니다.

Step 12− 다음 명령을 통해 노드 폴더에 대한 심볼릭 링크를 생성합니다. 이는 노드 패키지 관리자가 nodejs 설치를 찾을 수 있도록하는 데 도움이됩니다.

sudo ln -s /usr/bin/nodejs /usr/bin/node

Step 13− 이제 npm start 명령을 통해 Angular 2 애플리케이션을 시작할 차례입니다. 이것은 먼저 파일을 빌드 한 다음 이전 단계에서 설치 한 라이트 서버에서 Angular 앱을 시작합니다.

다음 명령을 실행하십시오-

sudo npm start

완료되면 URL이 표시됩니다.

URL로 이동하면 브라우저를로드하는 Angular 2 앱이 표시됩니다.

Ubuntu에 nginx 배포

Note− Angular JS 애플리케이션을 호스팅하기 위해 모든 플랫폼의 모든 웹 서버를 사용할 수 있습니다. 여기서는 인기있는 웹 서버 인 NGNIX를 예로 들어 보겠습니다.

Step 1 − Ubuntu 서버에서 다음 명령을 실행하여 nginx를 웹 서버로 설치합니다.

sudo apt-get update

이 명령은 시스템의 모든 패키지가 최신 상태인지 확인합니다.

완료되면 시스템이 최신 상태 여야합니다.

Step 2 − 이제 다음 명령을 실행하여 설치하십시오. nginx.

apt-get install nginx

완료되면 nginx가 백그라운드에서 실행됩니다.

Step 3 − 다음 명령을 실행하여 nginx 서비스가 실행 중입니다.

ps –ef | grep nginx

이제 기본적으로 nginx의 파일은 / var / www / html 폴더에 저장됩니다. 따라서 Hello World 파일을이 위치로 복사하는 데 필요한 권한을 부여하십시오.

Step 4 − 다음 명령을 실행합니다.

sudo chmod 777 /var/www/html

Step 5 − 임의의 방법으로 파일을 복사하여 프로젝트 파일을 / var / www / html 폴더에 복사합니다.

이제 URL로 이동하면- http://192.168.1.200/index.html Hello world Angular JS 애플리케이션을 찾을 수 있습니다.

모듈은 Angular JS에서 애플리케이션에 논리적 경계를 설정하는 데 사용됩니다. 따라서 모든 것을 하나의 애플리케이션으로 코딩하는 대신 모든 것을 별도의 모듈로 빌드하여 애플리케이션의 기능을 분리 할 수 ​​있습니다. 데모 애플리케이션에 추가되는 코드를 살펴 보겠습니다.

Visual Studio 코드에서 앱 폴더의 app.module.ts 폴더로 이동합니다. 이를 루트 모듈 클래스라고합니다.

다음 코드는 app.module.ts 파일.

import { NgModule }      from '@angular/core'; 
import { BrowserModule } from '@angular/platform-browser';  
import { AppComponent }  from './app.component';  

@NgModule ({ 
   imports:      [ BrowserModule ], 
   declarations: [ AppComponent ], 
   bootstrap:    [ AppComponent ] 
}) 
export class AppModule { }

코드의 각 줄을 자세히 살펴 보겠습니다.

  • import 문은 기존 모듈에서 기능을 가져 오는 데 사용됩니다. 따라서 처음 3 개의 문은 NgModule, BrowserModule 및 AppComponent 모듈을이 모듈로 가져 오는 데 사용됩니다.

  • NgModule 데코레이터는 나중에 가져 오기, 선언 및 부트 스트랩 옵션을 정의하는 데 사용됩니다.

  • BrowserModule은 기본적으로 모든 웹 기반 각도 응용 프로그램에 필요합니다.

  • 부트 스트랩 옵션은 애플리케이션에서 부트 스트랩 할 컴포넌트를 Angular에 알려줍니다.

모듈은 다음 부분으로 구성됩니다.

  • Bootstrap array− 이것은 Angular JS에게 어떤 컴포넌트를로드해야하는지 알려주는 데 사용되어 애플리케이션에서 해당 기능에 액세스 할 수 있습니다. 구성 요소를 부트 스트랩 배열에 포함하면 Angular JS 애플리케이션의 다른 구성 요소에서 사용할 수 있도록 선언해야합니다.

  • Export array − 다른 모듈에서 사용할 수있는 구성 요소, 지시문 및 파이프를 내보내는 데 사용됩니다.

  • Import array − 내보내기 배열과 마찬가지로 가져 오기 배열은 다른 Angular JS 모듈에서 기능을 가져 오는 데 사용할 수 있습니다.

다음 스크린 샷은 Angular 2 애플리케이션의 구조를 보여줍니다. 각 응용 프로그램은 구성 요소로 구성됩니다. 각 구성 요소는 응용 프로그램 기능의 논리적 경계입니다. 구성 요소간에 기능을 공유하는 데 사용되는 계층화 된 서비스가 필요합니다.

다음은 구성 요소의 구조입니다. 구성 요소는-

  • Class − 이것은 속성과 메소드로 구성된 C ++ 또는 Java 클래스와 같습니다.

  • Metadata − 클래스를 꾸미고 클래스의 기능을 확장하는 데 사용됩니다.

  • Template − 응용 프로그램에 표시되는 HTML보기를 정의하는 데 사용됩니다.

다음은 구성 요소의 예입니다.

import { Component } from '@angular/core';

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   appTitle: string = 'Welcome';
}

각 애플리케이션은 모듈로 구성됩니다. 각 Angular 2 응용 프로그램에는 하나의 Angular Root 모듈이 있어야합니다. 그런 다음 각 Angular Root 모듈은 기능을 분리하기 위해 여러 구성 요소를 가질 수 있습니다.

다음은 루트 모듈의 예입니다.

import { NgModule }      from '@angular/core'; 
import { BrowserModule } from '@angular/platform-browser'; 
import { AppComponent }  from './app.component';  

@NgModule ({ 
   imports:      [ BrowserModule ], 
   declarations: [ AppComponent ], 
   bootstrap:    [ AppComponent ] 
}) 
export class AppModule { }

각 애플리케이션은 각 모듈이 애플리케이션의 개별 기능을 갖는 기능 모듈로 구성됩니다. 각 Angular 기능 모듈은 기능을 분리하기 위해 여러 구성 요소를 가질 수 있습니다.

컴포넌트는 Angular JS 애플리케이션을위한 논리적 코드입니다. 구성 요소는 다음으로 구성됩니다-

  • Template− 애플리케이션의 뷰를 렌더링하는 데 사용됩니다. 여기에는 애플리케이션에서 렌더링해야하는 HTML이 포함됩니다. 이 부분에는 바인딩 및 지시문도 포함됩니다.

  • Class− 이것은 C와 같은 언어로 정의 된 클래스와 같습니다. 여기에는 속성과 메서드가 포함됩니다. 이것은 뷰를 지원하는 데 사용되는 코드를 가지고 있습니다. TypeScript에 정의되어 있습니다.

  • Metadata− Angular 클래스에 대해 정의 된 추가 데이터가 있습니다. 데코레이터로 정의됩니다.

이제 app.component.ts 파일로 이동하여 첫 번째 Angular 구성 요소를 만듭니다.

다음 코드를 파일에 추가하고 각 측면을 자세히 살펴 보겠습니다.

수업

클래스 데코레이터. 클래스는 TypeScript에서 정의됩니다. 클래스는 일반적으로 TypeScript에서 다음 구문을 사용합니다.

통사론

class classname {
   Propertyname: PropertyType = Value
}

매개 변수

  • Classname − 이것은 클래스에 부여 할 이름입니다.

  • Propertyname − 이것은 부동산에 부여 할 이름입니다.

  • PropertyType − TypeScript는 강력한 유형이므로 속성에 유형을 제공해야합니다.

  • Value − 이것은 부동산에 부여되는 값입니다.

export class AppComponent {
   appTitle: string = 'Welcome';
}

예제에서 다음 사항에주의해야합니다.

  • AppComponent라는 클래스를 정의하고 있습니다.

  • export 키워드는 컴포넌트가 Angular JS 애플리케이션의 다른 모듈에서 사용될 수 있도록 사용됩니다.

  • appTitle은 속성의 이름입니다.

  • 속성에는 문자열 유형이 제공됩니다.

  • 속성에 'Welcome'값이 지정됩니다.

주형

이것은 응용 프로그램에서 렌더링해야하는 뷰입니다.

통사론

Template: '
   <HTML code>
   class properties
'

매개 변수

  • HTML Code − 이것은 응용 프로그램에서 렌더링해야하는 HTML 코드입니다.

  • Class properties − 템플릿에서 참조 할 수있는 클래스의 속성입니다.

template: '
   <div>
      <h1>{{appTitle}}</h1>
      <div>To Tutorials Point</div>
   </div>
'

예제에서 다음 사항에주의해야합니다.

  • 애플리케이션에서 렌더링 될 HTML 코드를 정의하고 있습니다.

  • 또한 클래스에서 appTitle 속성을 참조하고 있습니다.

메타 데이터

추가 정보로 Angular JS 클래스를 장식하는 데 사용됩니다.

클래스, 템플릿 및 메타 데이터를 사용하여 완성 된 코드를 살펴 보겠습니다.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: ` <div>
      <h1>{{appTitle}}</h1>
      <div>To Tutorials Point</div>
   </div> `,
})

export class AppComponent {
   appTitle: string = 'Welcome';
}

위의 예에서 다음 사항에 유의해야합니다.

  • angular / core 모듈에서 'Component'데코레이터를 가져 오기 위해 import 키워드를 사용하고 있습니다.

  • 그런 다음 데코레이터를 사용하여 구성 요소를 정의합니다.

  • 구성 요소에는 'my-app'이라는 선택기가 있습니다. 이것은 기본 html 페이지에서 사용할 수있는 사용자 정의 html 태그에 불과합니다.

이제 코드의 index.html 파일로 이동해 보겠습니다.

이제 body 태그에 컴포넌트의 사용자 정의 태그에 대한 참조가 포함되어 있는지 확인하겠습니다. 따라서 위의 경우 body 태그에 다음 코드가 포함되어 있는지 확인해야합니다.

<body>
   <my-app></my-app>
</body>

산출

이제 브라우저로 이동하여 출력을 보면 출력이 구성 요소에있는 그대로 렌더링되는 것을 볼 수 있습니다.

구성 요소 장에서 이미 다음 템플릿의 예를 보았습니다.

template: '
   <div>
      <h1>{{appTitle}}</h1>
      <div>To Tutorials Point</div>
   </div>
'

이것은 inline template. 템플릿을 정의하는 다른 방법이 있으며 templateURL 명령을 통해 수행 할 수 있습니다. 컴포넌트에서 이것을 사용하는 가장 간단한 방법은 다음과 같습니다.

통사론

templateURL:
viewname.component.html

매개 변수

  • viewname − 앱 컴포넌트 모듈의 이름입니다.

뷰 이름 뒤에 구성 요소를 파일 이름에 추가해야합니다.

다음은 인라인 템플릿을 정의하는 단계입니다.

Step 1− app.component.html이라는 파일을 생성합니다. 여기에는보기에 대한 html 코드가 포함됩니다.

Step 2 − 위에서 생성 된 파일에 다음 코드를 추가합니다.

<div>{{appTitle}} Tutorialspoint </div>

이것은 간단한 div 태그를 정의하고 app.component 클래스의 appTitle 속성을 참조합니다.

Step 3 − app.component.ts 파일에 다음 코드를 추가합니다.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'  
})

export class AppComponent {
   appTitle: string = 'Welcome';
}

위의 코드에서 주목할 수있는 유일한 변경 사항은 앱 폴더에있는 app.component.html 파일에 대한 링크를 제공하는 templateURL입니다.

Step 4 − 브라우저에서 코드를 실행하면 다음과 같은 출력이 표시됩니다.

출력에서 템플릿 파일 (app.component.html) 파일이 그에 따라 호출되고 있음을 알 수 있습니다.

directiveHTML의 기능을 확장하는 데 사용되는 사용자 정의 HTML 요소입니다. Angular 2에는 BrowserModule 모듈의 일부로 호출되는 다음 지시문이 있습니다.

  • ngif
  • ngFor

app.module.ts 파일을 보면 다음 코드와 BrowserModule 모듈이 정의 된 것을 볼 수 있습니다. 이 모듈을 정의하면 2 개의 지시문에 액세스 할 수 있습니다.

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent }  from './app.component';

@NgModule ({
   imports:      [ BrowserModule ],
   declarations: [ AppComponent ],
   bootstrap:    [ AppComponent ]
})
export class AppModule { }

이제 각 지시문을 자세히 살펴 보겠습니다.

ngIf

그만큼 ngif 요소가 true로 평가되면 HTML 코드에 요소를 추가하는 데 사용됩니다. 그렇지 않으면 HTML 코드에 요소를 추가하지 않습니다.

통사론

*ngIf = 'expression'

표현식이 true로 평가되면 해당 항목이 추가되고 그렇지 않으면 요소가 추가되지 않습니다.

이제 * ngif 지시문을 사용하는 방법의 예를 살펴 보겠습니다.

Step 1− 먼저 appStatus라는 클래스에 속성을 추가합니다. 이것은 부울 유형입니다. 이 값을 true로 유지합시다.

import { Component } from '@angular/core';  

@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'
})

export class AppComponent {
   appTitle: string = 'Welcome';
   appStatus: boolean = true;
}

Step 2 − 이제 app.component.html 파일에 다음 코드를 추가하십시오.

<div *ngIf = 'appStatus'>{{appTitle}} Tutorialspoint </div>

위의 코드에는 * ngIf 지시문이 있습니다. 지시문에서 우리는 appStatus 속성의 값을 평가하고 있습니다. 속성 값이 true로 평가되어야하므로 div 태그가 브라우저에 표시되어야 함을 의미합니다.

위 코드를 추가하면 브라우저에 다음과 같은 출력이 표시됩니다.

산출

ngFor

그만큼 ngFor 요소는 For 루프의 조건에 따라 요소에 사용됩니다.

통사론

*ngFor = 'let variable of variablelist'

변수는 값을 표시하는 임시 변수입니다. variablelist.

이제 * ngFor 지시문을 사용하는 방법의 예를 살펴 보겠습니다.

Step 1− 먼저 appList라는 클래스에 속성을 추가합니다. 이것은 모든 유형의 배열을 정의하는 데 사용할 수있는 유형입니다.

import { Component } from '@angular/core';
 
@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'
})

export class AppComponent {
   appTitle: string = 'Welcome';
   appList: any[] = [ {
      "ID": "1",
      "Name" : "One"
   },

   {
      "ID": "2",
      "Name" : "Two"
   } ];
}

따라서 appList를 2 개의 요소가있는 배열로 정의합니다. 각 요소에는 ID와 이름으로 2 개의 하위 속성이 있습니다.

Step 2 − app.component.html에서 다음 코드를 정의하십시오.

<div *ngFor = 'let lst of appList'> 
   <ul> 
      <li>{{lst.ID}}</li> 
      <li>{{lst.Name}}</li> 
   </ul> 
</div>

위의 코드에서 이제 ngFor 지시문을 사용하여 appList 배열을 반복합니다. 그런 다음 각 목록 항목이 배열의 ID 및 이름 매개 변수 인 목록을 정의합니다.

위 코드를 추가하면 브라우저에 다음과 같은 출력이 표시됩니다.

산출

메타 데이터는 클래스의 예상 동작을 구성 할 수 있도록 클래스를 장식하는 데 사용됩니다. 다음은 메타 데이터의 다른 부분입니다.

Annotations− 이들은 학급 수준의 데코레이터입니다. 이것은 @Component 및 @Routes 데코레이터가 모두있는 배열 및 예제입니다.

다음은 app.component.ts 파일에있는 샘플 코드입니다.

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
})

컴포넌트 데코레이터는 app.component.ts 파일의 클래스를 컴포넌트로 선언하는 데 사용됩니다.

  • Design:paramtypes − 이는 생성자에만 사용되며 Typescript에만 적용됩니다.

  • propMetadata − 클래스의 속성에 적용되는 메타 데이터입니다.

다음은 예제 코드입니다.

export class AppComponent {
   @Environment(‘test’)
   appTitle: string = 'Welcome';
}

여기서 @Environment는 appTitle 속성에 적용된 메타 데이터이며 주어진 값은 'test'입니다.

Parameters − 이것은 생성자 수준에서 데코레이터에 의해 설정됩니다.

다음은 예제 코드입니다.

export class AppComponent {
   constructor(@Environment(‘test’ private appTitle:string) { }
}

위의 예에서 메타 데이터는 생성자의 매개 변수에 적용됩니다.

양방향 바인딩은 Angular JS의 기능 이었지만 Angular 2.x 이상에서는 제거되었습니다. 하지만 이제 Angular 2의 클래스 이벤트 이후 AngularJS 클래스의 속성에 바인딩 할 수 있습니다.

클래스 이름이있는 클래스, 유형과 값이있는 속성이 있다고 가정합니다.

export class className {
   property: propertytype = value;
}

그런 다음 html 태그의 속성을 클래스의 속성에 바인딩 할 수 있습니다.

<html tag htmlproperty = 'property'>

그러면 속성 값이 html의 htmlproperty에 할당됩니다.

데이터 바인딩을 수행하는 방법의 예를 살펴 보겠습니다. 이 예에서는 이미지 소스가 클래스의 속성에서 나오는 이미지를 표시하는 방법을 살펴 봅니다. 이를 달성하기위한 단계는 다음과 같습니다.

Step 1− 2 개의 이미지를 다운로드합니다. 이 예에서는 아래에 표시된 몇 가지 간단한 이미지를 다운로드합니다.

Step 2 − 이러한 이미지를 Images앱 디렉토리에 있습니다. 이미지 폴더가 없으면 새로 만드십시오.

Step 3 − 아래와 같이 app.component.ts에 다음 내용을 추가합니다.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'
})

export class AppComponent {
   appTitle: string = 'Welcome';
   appList: any[] = [ {
      "ID": "1",
      "url": 'app/Images/One.jpg'
   },

   {
      "ID": "2",
      "url": 'app/Images/Two.jpg'
   } ];
}

Step 4 − 아래와 같이 app.component.html에 다음 내용을 추가합니다.

<div *ngFor = 'let lst of appList'>
   <ul>
      <li>{{lst.ID}}</li>
      <img [src] = 'lst.url'>
   </ul>
</div>

위의 app.component.html 파일에서 클래스의 속성에서 이미지에 액세스하고 있습니다.

산출

위 프로그램의 출력은 다음과 같아야합니다.

이 장에서 살펴볼 기본 CRUD 작업은 Angular 2를 사용하여 웹 서비스에서 데이터를 읽는 것입니다.

이 예에서는 간단한 데이터 소스를 정의 할 것입니다. json제품 파일. 다음으로 데이터를 읽는 데 사용할 서비스를 정의하겠습니다.json파일. 그리고 다음으로 메인 app.component.ts 파일에서이 서비스를 사용합니다.

Step 1 − 먼저 Visual Studio 코드에서 product.json 파일을 정의하겠습니다.

products.json 파일에 다음 텍스트를 입력하십시오. 이것은 Angular JS 애플리케이션에서 가져온 데이터입니다.

[{
   "ProductID": 1,
   "ProductName": "ProductA"
},

{
   "ProductID": 2,
   "ProductName": "ProductB"
}]

Step 2− products.json 파일의 정보를 저장할 클래스 정의가 될 인터페이스를 정의합니다. products.ts라는 파일을 만듭니다.

Step 3 − 파일에 다음 코드를 삽입합니다.

export interface IProduct {
   ProductID: number;
   ProductName: string;
}

위의 인터페이스에는 인터페이스에 대한 속성으로 ProductID 및 ProductName에 대한 정의가 있습니다.

Step 4 − app.module.ts 파일에 다음 코드를 포함하세요 −

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent }  from './app.component';
import { HttpModule } from '@angular/http';

@NgModule ({
   imports:      [ BrowserModule,HttpModule],
   declarations: [ AppComponent],
   bootstrap:    [ AppComponent ]
})
export class AppModule { }

Step 5 − Visual Studio 코드에서 products.service.ts 파일 정의

Step 6 − 파일에 다음 코드를 삽입합니다.

import { Injectable } from '@angular/core';
import { Http , Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/do';
import { IProduct } from './product';

@Injectable()
export class ProductService {
   private _producturl='app/products.json';
   constructor(private _http: Http){}
   
   getproducts(): Observable<IProduct[]> {
      return this._http.get(this._producturl)
      .map((response: Response) => <IProduct[]> response.json())
      .do(data => console.log(JSON.stringify(data)));
   }
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • '@ angular / http'문에서 {Http, Response} 가져 오기는 http 함수를 사용하여 products.json 파일에서 데이터를 가져올 수 있는지 확인하는 데 사용됩니다.

  • 다음 문은 Observable 변수를 만드는 데 사용할 수있는 Reactive 프레임 워크를 사용하는 데 사용됩니다. Observable 프레임 워크는 http 응답의 변경 사항을 감지하는 데 사용되며 이는 기본 애플리케이션으로 다시 전송 될 수 있습니다.

import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/do';
  • 클래스의 private _producturl = 'app / products.json'문은 데이터 소스의 위치를 ​​지정하는 데 사용됩니다. 필요한 경우 웹 서비스의 위치를 ​​지정할 수도 있습니다.

  • 다음으로 데이터 소스에서 응답을 가져 오는 데 사용되는 Http 유형의 변수를 정의합니다.

  • 데이터 소스에서 데이터를 가져 오면 JSON.stringify (data) 명령을 사용하여 브라우저의 콘솔로 데이터를 보냅니다.

Step 7 − 이제 app.component.ts 파일에 다음 코드를 배치합니다.

import { Component } from '@angular/core';
import { IProduct } from './product';
import { ProductService } from './products.service';
import { appService } from './app.service';
import { Http , Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/map';

@Component ({
   selector: 'my-app',
   template: '<div>Hello</div>',
   providers: [ProductService]
})

export   class   AppComponent  {
   iproducts: IProduct[];
   constructor(private _product: ProductService) {
   }
   
   ngOnInit() : void {
      this._product.getproducts()
      .subscribe(iproducts => this.iproducts = iproducts);
   }
}

여기에서 코드에서 가장 중요한 것은 데이터 소스에서 데이터를 수신하기 위해 Observable getproducts () 함수를 수신하는 데 사용되는 구독 옵션입니다.

이제 모든 코드를 저장하고 다음을 사용하여 응용 프로그램을 실행하십시오. npm. 브라우저로 이동하면 다음 출력이 표시됩니다.

콘솔에서 products.json 파일에서 검색되는 데이터를 볼 수 있습니다.

Angular 2 응용 프로그램에는 오류 처리 옵션이 있습니다. 이것은 ReactJS catch 라이브러리를 포함하고 catch 함수를 사용하여 수행됩니다.

오류 처리에 필요한 코드를 살펴 보겠습니다. 이 코드는 http를 사용하는 CRUD 작업에 대한 장 상단에 추가 할 수 있습니다.

product.service.ts 파일에 다음 코드를 입력하십시오.

import { Injectable } from '@angular/core'; 
import { Http , Response } from '@angular/http'; 
import { Observable } from 'rxjs/Observable'; 

import 'rxjs/add/operator/map'; 
import 'rxjs/add/operator/do'; 
import 'rxjs/add/operator/catch'; 
import { IProduct } from './product';  

@Injectable() 
export class ProductService { 
   private _producturl = 'app/products.json'; 
   constructor(private _http: Http){}  

   getproducts(): Observable<IProduct[]> { 
      return this._http.get(this._producturl) 
      .map((response: Response) => <IProduct[]> response.json()) 
      .do(data => console.log(JSON.stringify(data))) 
      .catch(this.handleError); 
   }  
   
   private handleError(error: Response) { 
      console.error(error); 
      return Observable.throw(error.json().error()); 
   } 
}
  • catch 함수에는 오류 처리기 함수에 대한 링크가 포함되어 있습니다.

  • 오류 처리기 함수에서 오류를 콘솔로 보냅니다. 또한 실행을 계속할 수 있도록 오류를 기본 프로그램으로 다시 보냅니다.

이제 오류가 발생할 때마다 브라우저의 오류 콘솔로 리디렉션됩니다.

라우팅은 기본 페이지에서 선택한 옵션에 따라 사용자를 다른 페이지로 안내하는 데 도움이됩니다. 따라서 선택한 옵션에 따라 필요한 Angular 구성 요소가 사용자에게 렌더링됩니다.

Angular 2 애플리케이션에서 라우팅을 구현하는 방법을 확인하는 데 필요한 단계를 살펴 보겠습니다.

Step 1 − index.html 파일에 기본 참조 태그를 추가합니다.

<!DOCTYPE html>
<html>
   <head>
      <base href = "/">
      <title>Angular QuickStart</title>
      <meta charset = "UTF-8">
      <meta name = "viewport" content = "width = device-width, initial-scale = 1">
      
      <base href = "/">
      <link rel = "stylesheet" href = "styles.css">

      <!-- Polyfill(s) for older browsers -->
      <script src = "node_modules/core-js/client/shim.min.js"></script>
      <script src = "node_modules/zone.js/dist/zone.js"></script>
      <script src = "node_modules/systemjs/dist/system.src.js"></script>
      <script src = "systemjs.config.js"></script>

      <script>
         System.import('main.js').catch(function(err){ console.error(err); });
      </script>
   </head>

   <body>
      <my-app></my-app>
   </body>
</html>

Step 2− 응용 프로그램에 대한 두 개의 경로를 만듭니다. 이를 위해Inventory.component.tsproduct.component.ts

Step 3 − product.component.ts 파일에 다음 코드를 추가하십시오.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: 'Products',
})
export   class   Appproduct  {
}

Step 4 − Inventory.component.ts 파일에 다음 코드를 배치합니다.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: 'Inventory',
})
export class AppInventory  {
}

두 구성 요소 모두 멋진 작업을 수행하지 않고 구성 요소를 기반으로 키워드를 렌더링합니다. 따라서 인벤토리 구성 요소의 경우 사용자에게 인벤토리 키워드를 표시합니다. 그리고 제품 구성 요소의 경우 사용자에게 제품 키워드를 표시합니다.

Step 5 − app.module.ts 파일에 다음 코드를 추가하세요 −

import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent }  from './app.component';
import { Appproduct } from './product.component';
import { AppInventory } from './Inventory.component';
import { RouterModule, Routes } from '@angular/router';

const appRoutes: Routes = [
   { path: 'Product', component: Appproduct },
   { path: 'Inventory', component: AppInventory },
];

@NgModule ({
   imports: [ BrowserModule,
   RouterModule.forRoot(appRoutes)],
   declarations: [ AppComponent,Appproduct,AppInventory],
   bootstrap: [ AppComponent ]
})
export class AppModule { }

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • appRoutes에는 2 개의 경로가 포함되어 있습니다. 하나는 Appproduct 구성 요소이고 다른 하나는 AppInventory 구성 요소입니다.

  • 두 구성 요소를 모두 선언해야합니다.

  • RouterModule.forRoot는 애플리케이션에 경로를 추가하도록합니다.

Step 6 − app.component.ts 파일에 다음 코드를 추가합니다.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: `
   <ul>
      <li><a [routerLink] = "['/Product']">Product</a></li>
      <li><a [routerLink] = "['/Inventory']">Inventory</a></li>
   </ul>
   <router-outlet></router-outlet>`
})
export class AppComponent  { }

위의 프로그램에 대해 다음 사항에 유의해야합니다.

  • <router-outlet> </ router-outlet>은 사용자가 선택한 옵션에 따라 구성 요소를 렌더링하는 자리 표시 자입니다.

이제 모든 코드를 저장하고 npm을 사용하여 애플리케이션을 실행합니다. 브라우저로 이동하면 다음 출력이 표시됩니다.

이제 인벤토리 링크를 클릭하면 다음과 같은 출력이 표시됩니다.

오류 경로 추가

라우팅에서 오류 경로를 추가 할 수도 있습니다. 이는 사용자가 애플리케이션에없는 페이지로 이동하는 경우 발생할 수 있습니다.

이를 구현하는 방법을 살펴 보겠습니다.

Step 1 − 아래와 같이 PageNotFound 구성 요소를 NotFound.component.ts로 추가합니다. −

Step 2 − 새 파일에 다음 코드를 추가합니다.

import { Component } from '@angular/core';

@Component ({  
   selector: 'my-app',  
   template: 'Not Found', 
})  
export class PageNotFoundComponent {  
}

Step 3 − app.module.ts 파일에 다음 코드를 추가합니다.

import { NgModule } from '@angular/core'; 
import { BrowserModule } from '@angular/platform-browser'; 
import { AppComponent } from './app.component'; 
import { Appproduct } from './product.component' 
import { AppInventory } from  './Inventory.component' 
import { PageNotFoundComponent } from  './NotFound.component' 
import { RouterModule, Routes } from '@angular/router';  

const appRoutes: Routes = [ 
   { path: 'Product', component: Appproduct }, 
   { path: 'Inventory', component: AppInventory }, 
   { path: '**', component: PageNotFoundComponent } 
];  

@NgModule ({ 
   imports: [ BrowserModule, 
   RouterModule.forRoot(appRoutes)], 
   declarations: [ AppComponent,Appproduct,AppInventory,PageNotFoundComponent], 
   bootstrap: [ AppComponent ] 
}) 

export class AppModule {
}

위의 프로그램에 대해 다음 사항에 유의해야합니다.

  • 이제 path : '**', component : PageNotFoundComponent라는 추가 경로가 있습니다. 따라서 **는 기본 경로에 맞지 않는 모든 경로입니다. PageNotFoundComponent 구성 요소로 연결됩니다.

이제 모든 코드를 저장하고 npm을 사용하여 애플리케이션을 실행합니다. 브라우저로 이동하면 다음 출력이 표시됩니다. 이제 잘못된 링크로 이동하면 다음 출력이 표시됩니다.

Angular 2에서는 수동 탐색을 수행 할 수도 있습니다. 다음은 단계입니다.

Step 1 − Inventory.component.ts 파일에 다음 코드를 추가합니다.

import { Component } from '@angular/core'; 
import { Router }  from '@angular/router';  

@Component ({  
   selector: 'my-app',  
   template: 'Inventory 
   <a class = "button" (click) = "onBack()">Back to Products</a>' 
})  

export class AppInventory {  
   constructor(private _router: Router){} 

   onBack(): void { 
      this._router.navigate(['/Product']); 
   } 
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • 클릭 이벤트에 태그가 지정된 onBack 함수가있는 html 태그를 선언하십시오. 따라서 사용자가 이것을 클릭하면 제품 페이지로 다시 돌아갑니다.

  • onBack 기능에서 router.navigate를 사용하여 필요한 페이지로 이동하십시오.

Step 2− 이제 모든 코드를 저장하고 npm을 사용하여 응용 프로그램을 실행합니다. 브라우저로 이동하면 다음 출력이 표시됩니다.

Step 3 − 인벤토리 링크를 클릭합니다.

Step 4 − '제품으로 돌아 가기'링크를 클릭하면 제품 페이지로 돌아가는 다음 출력이 표시됩니다.

Angular 2는 다음을 사용하여 양방향 바인딩을 사용할 수있는 양식을 디자인 할 수도 있습니다. ngModel지령. 우리가 이것을 어떻게 달성 할 수 있는지 봅시다.

Step 1− 제품 모델 인 모델을 생성합니다. 라는 파일을 만듭니다.products.ts 파일.

Step 2 − 파일에 다음 코드를 넣으십시오.

export class Product { 
   constructor ( 
      public productid: number, 
      public productname: string 
   ) {  } 
}

이것은 productid와 productname이라는 2 개의 속성을 가진 간단한 클래스입니다.

Step 3 − product-form.component.ts 구성 요소라는 제품 양식 구성 요소를 만들고 다음 코드를 추가합니다.

import { Component } from '@angular/core';
import { Product } from './products';

@Component ({
   selector: 'product-form',
   templateUrl: './product-form.component.html'
})

export class ProductFormComponent {
   model = new Product(1,'ProductA');
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • Product 클래스의 개체를 만들고 productid 및 productname에 값을 추가합니다.

  • templateUrl을 사용하여 컴포넌트를 렌더링 할 product-form.component.html의 위치를 ​​지정하십시오.

Step 4− 실제 양식을 만듭니다. product-form.component.html이라는 파일을 만들고 다음 코드를 배치합니다.

<div class = "container">
   <h1>Product Form</h1>
   <form>
      <div class = "form-group">
         <label for = "productid">ID</label>
         <input type = "text" class = "form-control" id = "productid" required
            [(ngModel)] = "model.productid" name = "id">
      </div>
      
      <div class = "form-group">
         <label for = "name">Name</label>
         <input type = "text" class = "form-control" id = "name"
            [(ngModel)] = "model.productname" name = "name">
      </div>
   </form>
</div>

위의 프로그램에 대해 다음 사항에 유의해야합니다.

  • 그만큼 ngModel 지시문은 제품의 개체를 양식의 개별 요소에 바인딩하는 데 사용됩니다.

Step 5 − app.component.ts 파일에 다음 코드를 삽입합니다.

import { Component } from '@angular/core';

@Component ({
   selector: 'my-app',
   template: '<product-form></product-form>'
})
export class AppComponent { }

Step 6 − app.module.ts 파일에 아래 코드를 넣으십시오.

import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { FormsModule } from '@angular/forms';
import { ProductFormComponent } from './product-form.component';

@NgModule ({
   imports: [ BrowserModule,FormsModule],
   declarations: [ AppComponent,ProductFormComponent],
   bootstrap: [ AppComponent ]
})
export class AppModule { }

Step 7− 모든 코드를 저장하고 npm을 사용하여 응용 프로그램을 실행합니다. 브라우저로 이동하면 다음 출력이 표시됩니다.

명령 줄 인터페이스 (CLI)를 사용하여 Angular JS 애플리케이션을 만들 수 있습니다. 또한 응용 프로그램에 대한 단위 및 종단 간 테스트를 만드는 데 도움이됩니다.

Angular CLI의 공식 사이트는 https://cli.angular.io/

시작하기 옵션을 클릭하면 CLI 용 github 저장소로 이동합니다. https://github.com/angular/angular-cli

이제 Angular CLI로 수행 할 수있는 몇 가지 작업을 살펴 ​​보겠습니다.

CLI 설치

Note− 시스템에 Python이 설치되어 있는지 확인하십시오. Python은 사이트에서 다운로드 할 수 있습니다.https://www.python.org/

첫 번째 단계는 CLI를 설치하는 것입니다. 다음 명령으로이를 수행 할 수 있습니다.

npm install –g angular-cli

이제 임의의 디렉토리에 angularCLI라는 새 폴더를 만들고 위의 명령을 실행합니다.

완료되면 CLI가 설치됩니다.

프로젝트 생성

Angular JS 프로젝트는 다음 명령을 사용하여 생성 할 수 있습니다.

통사론

ng new Project_name

매개 변수

Project_name − 생성해야하는 프로젝트의 이름입니다.

산출

없음.

다음 명령을 실행하여 새 프로젝트를 생성 해 보겠습니다.

ng new demo2

자동으로 파일을 만들고 필요한 npm 패키지 다운로드를 시작합니다.

이제 Visual Studio 코드에서 새로 생성 된 프로젝트를 열 수 있습니다.

프로젝트 실행

프로젝트를 실행하려면 다음 명령을 실행해야합니다.

ng server

실행중인 애플리케이션의 기본 포트 번호는 4200입니다. 포트를 찾아보고 실행중인 애플리케이션을 볼 수 있습니다.

종속성 주입은 런타임에 구성 요소의 기능을 추가하는 기능입니다. 종속성 주입을 구현하는 데 사용되는 예제와 단계를 살펴 보겠습니다.

Step 1− 주입 가능한 데코레이터가있는 별도의 클래스를 만듭니다. 주입 가능한 데코레이터를 사용하면이 클래스의 기능을 모든 Angular JS 모듈에 주입하고 사용할 수 있습니다.

@Injectable() 
   export class classname {  
}

Step 2 − 다음으로 서비스를 사용하려는 appComponent 모듈 또는 모듈에서 @Component 데코레이터에서 제공자로 정의해야합니다.

@Component ({  
   providers : [classname] 
})

이를 달성하는 방법에 대한 예를 살펴 보겠습니다.

Step 1 − 만들기 ts app.service.ts라는 서비스 파일.

Step 2 − 위에서 생성 한 파일에 다음 코드를 삽입합니다.

import { 
   Injectable 
} from '@angular/core'; 

@Injectable() 
export class appService {  
   getApp(): string { 
      return "Hello world"; 
   } 
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • Injectable 데코레이터는 앵귤러 / 코어 모듈에서 가져옵니다.

  • Injectable 데코레이터로 장식 된 appService라는 클래스를 만듭니다.

  • "Hello world"라는 간단한 문자열을 반환하는 getApp이라는 간단한 함수를 만듭니다.

Step 3 − app.component.ts 파일에 다음 코드를 배치하십시오.

import { 
   Component 
} from '@angular/core';  

import { 
   appService 
} from './app.service';  

@Component({ 
   selector: 'my-app', 
   template: '<div>{{value}}</div>', 
   providers: [appService]  
}) 

export class AppComponent { 
   value: string = ""; 
   constructor(private _appService: appService) { } 
   ngOnInit(): void { 
      this.value = this._appService.getApp(); 
   }   
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • 먼저 appComponent 모듈에서 appService 모듈을 가져옵니다.

  • 그런 다음이 모듈에서 서비스를 공급자로 등록합니다.

  • 생성자에서 appService 유형의 _appService라는 변수를 정의하여 appComponent 모듈의 어느 곳에서나 호출 할 수 있도록합니다.

  • 예를 들어 ngOnInit 라이프 사이클 훅에서 서비스의 getApp 함수를 호출하고 출력을 AppComponent 클래스의 값 속성에 할당했습니다.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

이 장에서는 Angular 2 프로젝트의 일부인 다른 구성 파일을 살펴 보겠습니다.

tsconfig.json

이 파일은 Angular JS 프로젝트에 사용되는 TypeScript에 대한 옵션을 제공하는 데 사용됩니다.

{ 
   "compilerOptions": {
      "target": "es5",
      "module": "commonjs",
      "moduleResolution": "node",
      "sourceMap": true,
      "emitDecoratorMetadata": true,
      "experimentalDecorators": true,
      "lib": [ "es2015", "dom" ],
      "noImplicitAny": true,
      "suppressImplicitAnyIndexErrors": true
   }
}

다음은 위의 코드에 대해주의해야 할 몇 가지 핵심 사항입니다.

  • 컴파일 대상은 es5이며 대부분의 브라우저는 ES5 typescript 만 이해할 수 있기 때문입니다.

  • sourceMap 옵션은 디버깅 할 때 유용한 맵 파일을 생성하는 데 사용됩니다. 따라서 개발 중에이 옵션을 그대로 유지하는 것이 좋습니다.

  • "emitDecoratorMetadata": true 및 "experimentalDecorators": true는 Angular JS 데코레이터에 필요합니다. 제자리에 있지 않으면 Angular JS 응용 프로그램이 컴파일되지 않습니다.

package.json

이 파일에는 Angular 2 프로젝트에 대한 정보가 포함되어 있습니다. 다음은 파일의 일반적인 설정입니다.

{
   "name": "angular-quickstart",
   "version": "1.0.0",
   "description": "QuickStart package.json from the documentation,
      supplemented with testing support",
   
   "scripts": {
      "build": "tsc -p src/",
      "build:watch": "tsc -p src/ -w",
      "build:e2e": "tsc -p e2e/",
      "serve": "lite-server -c=bs-config.json",
      "serve:e2e": "lite-server -c=bs-config.e2e.json",
      "prestart": "npm run build",
      "start": "concurrently \"npm run build:watch\" \"npm run serve\"",
      "pree2e": "npm run build:e2e",
      "e2e": "concurrently \"npm run serve:e2e\" \"npm run protractor\" 
         --killothers --success first",
      "preprotractor": "webdriver-manager update",
      "protractor": "protractor protractor.config.js",
      "pretest": "npm run build",
      "test": "concurrently \"npm run build:watch\" \"karma start karma.conf.js\"",
      "pretest:once": "npm run build",
      "test:once": "karma start karma.conf.js --single-run",
      "lint": "tslint ./src/**/*.ts -t verbose"
   },

   "keywords": [],
   "author": "",
   "license": "MIT",
   "dependencies": {
      "@angular/common": "~2.4.0",
      "@angular/compiler": "~2.4.0",
      "@angular/core": "~2.4.0",
      "@angular/forms": "~2.4.0",
      "@angular/http": "~2.4.0",
      "@angular/platform-browser": "~2.4.0",
      "@angular/platform-browser-dynamic": "~2.4.0",
      "@angular/router": "~3.4.0",
      "angular-in-memory-web-api": "~0.2.4",
      "systemjs": "0.19.40",
      "core-js": "^2.4.1",
      "rxjs": "5.0.1",
      "zone.js": "^0.7.4"
   },

   "devDependencies": {
      "concurrently": "^3.2.0",
      "lite-server": "^2.2.2",
      "typescript": "~2.0.10",
      "canonical-path": "0.0.2",
      "tslint": "^3.15.1",
      "lodash": "^4.16.4",
      "jasmine-core": "~2.4.1",
      "karma": "^1.3.0",
      "karma-chrome-launcher": "^2.0.0",
      "karma-cli": "^1.0.1",
      "karma-jasmine": "^1.0.2",
      "karma-jasmine-html-reporter": "^0.2.2",
      "protractor": "~4.0.14",
      "rimraf": "^2.5.4",
      "@types/node": "^6.0.46",
      "@types/jasmine": "2.5.36"
   },
   "repository": {}
}

위의 코드에 대해 주목해야 할 몇 가지 핵심 사항-

  • 종속성에는 두 가지 유형이 있습니다. 첫 번째는 종속성이고 그 다음에는 개발 종속성이 있습니다. 개발 프로세스에는 개발 프로세스가 필요하고 다른 애플리케이션은 애플리케이션을 실행하는 데 필요합니다.

  • "build : watch": "tsc -p src / -w"명령은 typescript 파일에서 변경 사항을 찾아 백그라운드에서 typescript를 컴파일하는 데 사용됩니다.

systemjs.config.json

이 파일에는 Angular JS 애플리케이션에 필요한 시스템 파일이 포함되어 있습니다. 이렇게하면 html 페이지에 스크립트 태그를 추가 할 필요없이 필요한 모든 스크립트 파일이로드됩니다. 일반적인 파일에는 다음 코드가 있습니다.

/** 
 * System configuration for Angular samples 
 * Adjust as necessary for your application needs. 
*/ 
(function (global) { 
   System.config ({ 
      paths: { 
         // paths serve as alias 
         'npm:': 'node_modules/' 
      }, 
      
      // map tells the System loader where to look for things 
      map: { 
         // our app is within the app folder 
         app: 'app',  
         
         // angular bundles 
         '@angular/core': 'npm:@angular/core/bundles/core.umd.js', 
         '@angular/common': 'npm:@angular/common/bundles/common.umd.js', 
         '@angular/compiler': 'npm:@angular/compiler/bundles/compiler.umd.js', 
         '@angular/platform-browser': 'npm:@angular/platformbrowser/bundles/platform-browser.umd.js', 
         '@angular/platform-browser-dynamic': 
            'npm:@angular/platform-browserdynamic/bundles/platform-browser-dynamic.umd.js', 
         '@angular/http': 'npm:@angular/http/bundles/http.umd.js', 
         '@angular/router': 'npm:@angular/router/bundles/router.umd.js', 
         '@angular/forms': 'npm:@angular/forms/bundles/forms.umd.js',  
         
         // other libraries 
         'rxjs':  'npm:rxjs', 
         'angular-in-memory-web-api': 
            'npm:angular-in-memory-web-api/bundles/inmemory-web-api.umd.js' 
      }, 
     
      // packages tells the System loader how to load when no filename 
         and/or no extension 
      packages: { 
         app: { 
            defaultExtension: 'js' 
         }, 
         
         rxjs: { 
            defaultExtension: 'js' 
         } 
      } 
   
   }); 
})(this);

위의 코드에 대해 주목해야 할 몇 가지 핵심 사항-

  • 'npm :': 'node_modules /'는 모든 npm 모듈이있는 프로젝트의 위치를 ​​알려줍니다.

  • app : 'app'의 매핑은 모든 애플리케이션 파일이로드 된 폴더를 알려줍니다.

Angular 2를 사용하면 타사 컨트롤을 사용할 수 있습니다. 구현할 컨트롤을 결정하면 다음 단계를 수행해야합니다.

Step 1 − npm 명령을 사용하여 구성 요소를 설치합니다.

예를 들어 다음 명령을 통해 ng2-pagination 타사 컨트롤을 설치합니다.

npm install ng2-pagination --save

완료되면 구성 요소가 성공적으로 설치되었음을 알 수 있습니다.

Step 2 − app.module.ts 파일에 구성 요소를 포함합니다.

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent }  from './app.component';
import {Ng2PaginationModule} from 'ng2-pagination';

@NgModule ({
   imports:      [ BrowserModule,Ng2PaginationModule],
   declarations: [ AppComponent],
   bootstrap:    [ AppComponent ]
})
export class AppModule { }

Step 3 − 마지막으로 app.component.ts 파일에서 구성 요소를 구현합니다.

import { Component } from '@angular/core';
import {PaginatePipe, PaginationService} from 'ng2-pagination';

@Component ({
   selector: 'my-app',
   template: '
      <ul>
         <li *ngFor = "let item of collection | paginate: {
            itemsPerPage: 5, currentPage: p }"> ... </li>
      </ul>
      <pagination-controls (pageChange) = "p = $event"></pagination-controls>
   '
})
export class AppComponent { }

Step 4 − 모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음과 같은 출력이 표시됩니다.

위 그림에서 이미지가 Images 폴더에 One.jpg와 two.jpg로 저장되어 있음을 알 수 있습니다.

Step 5 − app.component.ts 파일의 코드를 다음과 같이 변경합니다.

import {
   Component
} from '@angular/core';

@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'
})

export class AppComponent {
   appTitle: string = 'Welcome';
   
   appList: any[] = [{
      "ID": "1",
      "Name": "One",
      "url": 'app/Images/One.jpg'
   },
   {
      "ID": "2",
      "Name": "Two",
      "url": 'app/Images/two.jpg'
   } ];
}

위 코드에 대해 다음 사항에 유의해야합니다.

  • any 유형의 appList라는 배열을 정의하고 있습니다. 이는 모든 유형의 요소를 저장할 수 있도록하기위한 것입니다.

  • 우리는 두 가지 요소를 정의하고 있습니다. 각 요소에는 3 개의 속성, ID, 이름 및 URL이 있습니다.

  • 각 요소의 URL은 2 개의 이미지에 대한 상대 경로입니다.

Step 6 − 템플릿 파일 인 app / app.component.html 파일을 다음과 같이 변경합니다.

<div *ngFor = 'let lst of appList'> 
   <ul> 
      <li>{{lst.ID}}</li> 
      <li>{{lst.Name}}</li> 
      <img [src] = 'lst.url'> 
   </ul> 
</div>

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • ngFor 지시문은 appList 속성의 모든 요소를 ​​반복하는 데 사용됩니다.

  • 각 속성에 대해 목록 요소를 사용하여 이미지를 표시합니다.

  • 그러면 img 태그의 src 속성이 우리 클래스의 appList의 url 속성에 바인딩됩니다.

Step 7− 모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음과 같은 출력이 표시됩니다. 출력에서 이미지가 선택되어 출력에 표시되었음을 명확하게 볼 수 있습니다.

Angular JS에서는 클래스의 속성 값을 HTML 형식으로 표시하는 것이 매우 쉽습니다.

예를 들어 데이터 표시에 대해 더 많이 이해해 봅시다. 이 예에서는 클래스의 다양한 속성 값을 HTML 페이지에 표시하는 방법을 살펴 봅니다.

Step 1 − app.component.ts 파일의 코드를 다음과 같이 변경합니다.

import {
   Component
} from '@angular/core';

@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'
})

export class AppComponent {
   TutorialName: string = 'Angular JS2';
   appList: string[] = ["Binding", "Display", "Services"];
}

위 코드에 대해 다음 사항에 유의해야합니다.

  • 우리는 문자열 유형의 appList라는 배열을 정의하고 있습니다.

  • 우리는 Binding, Display 및 Services 인 배열의 일부로 3 개의 문자열 요소를 정의하고 있습니다.

  • 또한 Angular 2의 값을 가진 TutorialName이라는 속성을 정의했습니다.

Step 2 − 템플릿 파일 인 app / app.component.html 파일을 다음과 같이 변경합니다.

<div>
   The name of this Tutorial is {{TutorialName}}<br>
   The first Topic is {{appList[0]}}<br>
   The second Topic is {{appList[1]}}<br>
   The third Topic is {{appList[2]}}<br>
</div>

위 코드에 대해 다음 사항에 유의해야합니다.

  • TutorialName 속성을 참조하여 "HTML 페이지의 자습서 이름이 무엇인지"알려줍니다.

  • 배열의 인덱스 값을 사용하여 배열의 3 개 주제를 각각 표시합니다.

Step 3− 모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 아래와 같은 출력이 표시됩니다. 출력에서 데이터가 클래스의 속성 값에 따라 표시되는 것을 명확하게 볼 수 있습니다.

즉석에서 바인딩하는 또 다른 간단한 예는 input html 태그를 사용하는 것입니다. html 태그에 데이터를 입력 할 때 데이터 만 표시합니다.

템플릿 파일 인 app / app.component.html 파일을 다음과 같이 변경합니다.

<div>
   <input [value] = "name" (input) = "name = $event.target.value">
   {{name}}
</div>

위 코드에 대해 다음 사항에 유의해야합니다.

  • [value] = ”username” − 사용자 이름 표현식을 입력 요소의 값 속성에 바인딩하는 데 사용됩니다.

  • (input) = ”expression” − 이것은 입력 요소의 입력 이벤트에 표현식을 바인딩하는 선언적 방법입니다.

  • username = $event.target.value − 입력 이벤트 발생시 실행되는 표현식.

  • $event − 이벤트의 페이로드 값을 갖는 Angular에 의해 이벤트 바인딩에 노출 된 표현식.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

이제 입력 상자에 "Tutorialspoint"와 같은 것을 입력합니다. 그에 따라 출력이 변경됩니다.

Angular 2에서는 버튼 클릭이나 다른 종류의 이벤트와 같은 이벤트도 매우 쉽게 처리 할 수 ​​있습니다. 이벤트는 html 페이지에서 트리거되고 추가 처리를 위해 Angular JS 클래스로 전송됩니다.

이벤트 핸들링을 달성 할 수있는 방법의 예를 살펴 보겠습니다. 이 예에서는 클릭 버튼과 상태 속성 표시를 살펴 보겠습니다. 처음에는 상태 속성이 true입니다. 버튼을 클릭하면 상태 속성이 false가됩니다.

Step 1 − app.component.ts 파일의 코드를 다음과 같이 변경합니다.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   Status: boolean = true; 
   clicked(event) { 
      this.Status = false; 
   } 
}

위 코드에 대해 다음 사항에 유의해야합니다.

  • 초기에 참인 부울 유형의 상태라는 변수를 정의하고 있습니다.

  • 다음으로 html 페이지에서 버튼을 클릭 할 때마다 호출되는 clicked 함수를 정의합니다. 함수에서 Status 속성 값을 true에서 false로 변경합니다.

Step 2 − 템플릿 파일 인 app / app.component.html 파일을 다음과 같이 변경합니다.

<div> 
   {{Status}} 
   <button (click) = "clicked()">Click</button> 
</div>

위 코드에 대해 다음 사항에 유의해야합니다.

  • 먼저 클래스의 Status 속성 값을 표시합니다.

  • 그런 다음 Click 값으로 button html 태그를 정의합니다. 그런 다음 버튼의 클릭 이벤트가 클래스의 클릭 이벤트에 대해 트리거되는지 확인합니다.

Step 3 − 모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음과 같은 출력이 표시됩니다.

Step 4 − 클릭 버튼을 클릭하면 다음과 같은 출력이 나타납니다.

Angular 2에는 데이터를 변환하는 데 사용할 수있는 많은 필터와 파이프가 있습니다.

소문자

입력을 모두 소문자로 변환하는 데 사용됩니다.

통사론

Propertyvalue | lowercase

매개 변수

없음

결과

속성 값이 소문자로 변환됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import { 
   Component 
} from '@angular/core'; 

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   TutorialName: string = 'Angular JS2'; 
   appList: string[] = ["Binding", "Display", "Services"]; 
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div> 
   The name of this Tutorial is {{TutorialName}}<br>  
   The first Topic is {{appList[0] | lowercase}}<br> 
   The second Topic is {{appList[1] | lowercase}}<br> 
   The third Topic is {{appList[2]| lowercase}}<br> 
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

대문자

입력을 모두 대문자로 변환하는 데 사용됩니다.

통사론

Propertyvalue | uppercase

매개 변수

없음.

결과

속성 값이 대문자로 변환됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import { 
   Component 
} from '@angular/core';

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   TutorialName: string = 'Angular JS2'; 
   appList: string[] = ["Binding", "Display", "Services"]; 
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div> 
   The name of this Tutorial is {{TutorialName}}<br>  
   The first Topic is {{appList[0] | uppercase }}<br> 
   The second Topic is {{appList[1] | uppercase }}<br> 
   The third Topic is {{appList[2]| uppercase }}<br> 
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

일부분

입력 문자열에서 데이터 조각을 분할하는 데 사용됩니다.

통사론

Propertyvalue | slice:start:end

매개 변수

  • start − 이것은 슬라이스가 시작되어야하는 시작 위치입니다.

  • end − 이것은 슬라이스가 끝나야하는 시작 위치입니다.

결과

속성 값은 시작 및 끝 위치를 기준으로 슬라이스됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import {
   Component
} from '@angular/core';

@Component ({
   selector: 'my-app',
   templateUrl: 'app/app.component.html'
})

export class AppComponent {
   TutorialName: string = 'Angular JS2';
   appList: string[] = ["Binding", "Display", "Services"];
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div> 
   The name of this Tutorial is {{TutorialName}}<br>  
   The first Topic is {{appList[0] | slice:1:2}}<br> 
   The second Topic is {{appList[1] | slice:1:3}}<br> 
   The third Topic is {{appList[2]| slice:2:3}}<br> 
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

데이트

입력 문자열을 날짜 형식으로 변환하는 데 사용됩니다.

통사론

Propertyvalue | date:”dateformat”

매개 변수

dateformat − 이것은 입력 문자열을 변환해야하는 날짜 형식입니다.

결과

속성 값이 날짜 형식으로 변환됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   newdate = new Date(2016, 3, 15);
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div> 
   The date of this Tutorial is {{newdate | date:"MM/dd/yy"}}<br>  
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

통화

입력 문자열을 통화 형식으로 변환하는 데 사용됩니다.

통사론

Propertyvalue | currency

매개 변수

없음.

결과

속성 값이 통화 형식으로 변환됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   newValue: number = 123; 
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div> 
   The currency of this Tutorial is {{newValue | currency}}<br>      
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

백분율

입력 문자열을 백분율 형식으로 변환하는 데 사용됩니다.

통사론

Propertyvalue | percent

매개 변수

없음

결과

속성 값은 백분율 형식으로 변환됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   newValue: number = 30; 
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div>
   The percentage is {{newValue | percent}}<br> 
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

백분율 파이프에는 다음과 같은 또 다른 변형이 있습니다.

통사론

Propertyvalue | percent: ‘{minIntegerDigits}.{minFractionDigits}{maxFractionDigits}’

매개 변수

  • minIntegerDigits − 이것은 정수의 최소 자릿수입니다.

  • minFractionDigits − 이것은 분수 자릿수의 최소 수입니다.

  • maxFractionDigits − 최대 분수 자릿수입니다.

결과

속성 값이 백분율 형식으로 변환됩니다.

먼저 app.component.ts 파일에 다음 코드가 있는지 확인하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   templateUrl: 'app/app.component.html' 
}) 

export class AppComponent { 
   newValue: number = 0.3; 
}

다음으로 app / app.component.html 파일에 다음 코드가 있는지 확인하십시오.

<div> 
   The percentage is {{newValue | percent:'2.2-5'}}<br>  
</div>

산출

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

Angular 2에는 사용자 지정 파이프를 만드는 기능도 있습니다. 사용자 지정 파이프를 정의하는 일반적인 방법은 다음과 같습니다.

import { Pipe, PipeTransform } from '@angular/core';  
@Pipe({name: 'Pipename'}) 

export class Pipeclass implements PipeTransform { 
   transform(parameters): returntype { } 
}

어디,

  • 'Pipename' − 이것은 파이프의 이름입니다.

  • Pipeclass − 이것은 사용자 지정 파이프에 할당 된 클래스의 이름입니다.

  • Transform − 배관 작업을하는 기능입니다.

  • Parameters − 파이프로 전달되는 매개 변수입니다.

  • Returntype − 이것은 파이프의 반환 유형입니다.

2 개의 숫자를 곱하는 사용자 지정 파이프를 만들어 보겠습니다. 그런 다음 컴포넌트 클래스에서 해당 파이프를 사용합니다.

Step 1 − 먼저 multiplier.pipe.ts라는 파일을 생성합니다.

Step 2 − 위에서 생성 된 파일에 다음 코드를 삽입합니다.

import { 
   Pipe, 
   PipeTransform 
} from '@angular/core';  

@Pipe ({ 
   name: 'Multiplier' 
}) 

export class MultiplierPipe implements PipeTransform { 
   transform(value: number, multiply: string): number { 
      let mul = parseFloat(multiply); 
      return mul * value 
   } 
}

위 코드에 대해 다음 사항에 유의해야합니다.

  • 먼저 Pipe 및 PipeTransform 모듈을 가져옵니다.

  • 그런 다음 'Multiplier'라는 이름으로 파이프를 생성합니다.

  • PipeTransform 모듈을 구현하는 MultiplierPipe라는 클래스를 만듭니다.

  • 그런 다음 변환 함수는 값과 여러 매개 변수를 받아 두 숫자의 곱셈을 출력합니다.

Step 3 − app.component.ts 파일에 다음 코드를 추가하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   template: '<p>Multiplier: {{2 | Multiplier: 10}}</p>' 
}) 
export class AppComponent {  }

Note − 템플릿에서는 새로운 맞춤형 파이프를 사용합니다.

Step 4 − app.module.ts 파일에 다음 코드가 있는지 확인하십시오.

import {
   NgModule
} from '@angular/core';

import {
   BrowserModule
} from '@angular/platform-browser';

import {
   AppComponent
} from './app.component';

import {
   MultiplierPipe
} from './multiplier.pipe'

@NgModule ({
   imports: [BrowserModule],
   declarations: [AppComponent, MultiplierPipe],
   bootstrap: [AppComponent]
})

export class AppModule {}

위 코드에 대해 다음 사항에 유의해야합니다.

  • MultiplierPipe 모듈을 포함해야합니다.

  • 또한 선언 섹션에 포함되어 있는지 확인해야합니다.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

Angular 2에서는 HTML의 DOM 요소 구조를 사용하여 런타임에 요소의 값을 변경할 수 있습니다. 좀 더 자세히 살펴 보겠습니다.

입력 태그

app.component.ts 파일에 다음 코드를 배치하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   template: ' 
      <div> 
         <input [value] = "name" (input) = "name = $event.target.value"> 
         {{name}} 
      </div> 
   ' 
}) 
export class AppComponent { }

위 코드에 대해 다음 사항에 유의해야합니다.

  • [value] = ”username” − 사용자 이름 표현식을 입력 요소의 값 속성에 바인딩하는 데 사용됩니다.

  • (input) = ”expression” − 이것은 입력 요소의 입력 이벤트에 표현식을 바인딩하는 선언적 방법입니다.

  • username = $event.target.value − 입력 이벤트 발생시 실행되는 표현식.

  • $event − 이벤트의 페이로드 값을 갖는 Angular에 의해 이벤트 바인딩에 노출 된 표현식입니다.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

이제 무엇이든 입력 할 수 있으며 동일한 입력이 입력 컨트롤 옆의 텍스트에 반영됩니다.

클릭 입력

app.component.ts 파일에 다음 코드를 배치하십시오.

import {
   Component
} from '@angular/core';

@Component ({
   selector: 'my-app',
   template: '<button (click) = "onClickMe()"> Click Me </button> {{clickMessage}}'
})

export class AppComponent {
   clickMessage = 'Hello';
   onClickMe() {
      this.clickMessage = 'This tutorial!';
   }
}

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

Click Me 버튼을 누르면 다음과 같은 출력이 표시됩니다.

Angular 2 응용 프로그램은 전체 프로세스 집합을 거치거나 시작부터 응용 프로그램 끝까지의 수명주기를 갖습니다.

다음 다이어그램은 Angular 2 애플리케이션 라이프 사이클의 전체 프로세스를 보여줍니다.

다음은 각 라이프 사이클 후크에 대한 설명입니다.

  • ngOnChanges − 데이터 바인딩 된 속성의 값이 변경되면이 메서드가 호출됩니다.

  • ngOnInit − Angular가 데이터 바인딩 된 속성을 처음 표시 한 후 지시문 / 구성 요소의 초기화가 발생할 때마다 호출됩니다.

  • ngDoCheck − 이는 Angular가 자체적으로 감지 할 수 없거나 감지 할 수없는 변경 사항을 감지하고 조치를 취하기위한 것입니다.

  • ngAfterContentInit − Angular가 컴포넌트 뷰에 외부 콘텐츠를 투사 한 후 호출됩니다.

  • ngAfterContentChecked − Angular가 컴포넌트에 투영 된 내용을 확인한 후 호출됩니다.

  • ngAfterViewInit − Angular가 컴포넌트의 뷰와 자식 뷰를 초기화 한 후 호출됩니다.

  • ngAfterViewChecked − Angular가 컴포넌트의 뷰와 자식 뷰를 확인한 후 응답으로 호출됩니다.

  • ngOnDestroy − Angular가 디렉티브 / 컴포넌트를 파괴하기 직전의 정리 단계입니다.

다음은 하나의 수명주기 후크를 구현하는 예입니다. 에서app.component.ts 파일에 다음 코드를 넣으십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   template: '<div> {{values}} </div> ' 
}) 

export class AppComponent { 
   values = ''; 
   ngOnInit() { 
      this.values = "Hello"; 
   } 
}

위의 프로그램에서 우리는 ngOnInit 수명주기 후크를 통해 this.values 매개 변수는 "Hello"로 설정되어야합니다.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

Angular JS에서는 컨테이너를 서로 중첩 할 수 있습니다. 외부 컨테이너를 부모 컨테이너라고하고 내부 컨테이너를 자식 컨테이너라고합니다. 이를 달성하는 방법에 대한 예를 살펴 보겠습니다. 다음은 단계입니다.

Step 1 − 만들기 ts 하위 컨테이너에 대한 파일 child.component.ts.

Step 2 − 위 단계에서 생성 한 파일에 다음 코드를 입력합니다.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'child-app', 
   template: '<div> {{values}} </div> ' 
}) 

export class ChildComponent { 
   values = ''; 
   ngOnInit() { 
      this.values = "Hello"; 
   } 
}

위의 코드는 this.values ​​매개 변수의 값을 "Hello"로 설정합니다.

Step 3 − app.component.ts 파일에 다음 코드를 추가하십시오.

import { 
   Component 
} from '@angular/core'; 

import { 
   ChildComponent 
} from './child.component'; 

@Component ({ 
   selector: 'my-app', 
   template: '<child-app></child-app> ' 
}) 

export class AppComponent { }

위 코드에서 이제 import 문을 호출하여 child.component기준 치수. 또한 하위 구성 요소에서 기본 구성 요소로 <child-app> 선택기를 호출합니다.

Step 4 − 다음으로 하위 구성 요소도 app.module.ts 파일에 포함되어 있는지 확인해야합니다.

import { 
   NgModule 
} from '@angular/core'; 

import { 
   BrowserModule 
} from '@angular/platform-browser';  

import { 
   AppComponent 
} from './app.component';  

import { 
   MultiplierPipe 
} from './multiplier.pipe' 

import { 
   ChildComponent 
} from './child.component';  

@NgModule ({ 
   imports: [BrowserModule], 
   declarations: [AppComponent, MultiplierPipe, ChildComponent], 
   bootstrap: [AppComponent] 
}) 

export class AppModule {}

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.

서비스는 다양한 모듈에 공통 기능을 제공해야 할 때 사용됩니다. 예를 들어, 다양한 모듈에서 재사용 할 수있는 데이터베이스 기능을 가질 수 있습니다. 따라서 데이터베이스 기능을 가질 수있는 서비스를 만들 수 있습니다.

서비스를 만들 때 다음과 같은 주요 단계를 수행해야합니다.

Step 1− 주입 가능한 데코레이터가있는 별도의 클래스를 만듭니다. 주입 가능한 데코레이터를 사용하면이 클래스의 기능을 모든 Angular JS 모듈에 주입하고 사용할 수 있습니다.

@Injectable() 
   export class classname {  
}

Step 2 − 다음으로 서비스를 사용하려는 appComponent 모듈 또는 모듈에서 @Component 데코레이터에서 제공자로 정의해야합니다.

@Component ({  
   providers : [classname] 
})

이를 달성하는 방법에 대한 예를 살펴 보겠습니다. 다음은 관련된 단계입니다.

Step 1 − 만들기 ts app.service.ts라는 서비스 파일.

Step 2 − 위에서 생성 한 파일에 다음 코드를 삽입합니다.

import { 
   Injectable 
} from '@angular/core';  

@Injectable()
export class appService {  
   getApp(): string { 
      return "Hello world"; 
   } 
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • Injectable 데코레이터는 앵귤러 / 코어 모듈에서 가져옵니다.

  • Injectable 데코레이터로 장식 된 appService라는 클래스를 만듭니다.

  • "Hello world"라는 간단한 문자열을 반환하는 getApp이라는 간단한 함수를 만들고 있습니다.

Step 3 − app.component.ts 파일에 다음 코드를 추가하십시오.

import { 
   Component 
} from '@angular/core';  

import { 
   appService 
} from './app.service';  

@Component ({ 
   selector: 'demo-app', 
   template: '<div>{{value}}</div>', 
   providers: [appService] 
}) 

export class AppComponent { 
   value: string = ""; 
   constructor(private _appService: appService) { }  

   ngOnInit(): void { 
      this.value = this._appService.getApp(); 
   } 
}

위 프로그램에 대해 다음 사항에 유의해야합니다.

  • 먼저 appComponent 모듈에서 appService 모듈을 가져옵니다.

  • 그런 다음이 모듈에서 서비스를 공급자로 등록합니다.

  • 생성자에서 appService 유형의 _appService라는 변수를 정의하여 appComponent 모듈의 어느 곳에서나 호출 할 수 있도록합니다.

  • 예를 들어 ngOnInit 라이프 사이클 훅에서 서비스의 getApp 함수를 호출하고 출력을 AppComponent 클래스의 값 속성에 할당합니다.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.