AngularJS-개요

AngularJS는 오픈 소스 웹 애플리케이션 프레임 워크입니다. 원래 Misko Hevery와 Adam Abrons가 2009 년에 개발했습니다. 이제 Google에서 관리합니다. 최신 버전은 1.2.21입니다.

공식 문서 에 명시된 AngularJS의 정의는 다음과 같습니다.

AngularJS는 동적 웹 애플리케이션을위한 구조적 프레임 워크입니다. HTML을 템플릿 언어로 사용하고 HTML 구문을 확장하여 애플리케이션 구성 요소를 명확하고 간결하게 표현할 수 있습니다. 데이터 바인딩 및 종속성 주입은 현재 작성해야하는 많은 코드를 제거합니다. 그리고 모든 것이 브라우저 내에서 이루어 지므로 모든 서버 기술과의 이상적인 파트너가됩니다.

일반적인 특징

AngularJS의 일반적인 기능은 다음과 같습니다.

  • AngularJS는 리치 인터넷 애플리케이션 (RIA)을 생성 할 수있는 효율적인 프레임 워크입니다.

  • AngularJS는 개발자에게 깨끗한 MVC (Model View Controller) 방식으로 JavaScript를 사용하여 클라이언트 측 애플리케이션을 작성할 수있는 옵션을 제공합니다.

  • AngularJS로 작성된 애플리케이션은 브라우저 간 호환됩니다. AngularJS는 각 브라우저에 적합한 JavaScript 코드를 자동으로 처리합니다.

  • AngularJS는 오픈 소스이며 완전 무료이며 전 세계 수천 명의 개발자가 사용합니다. Apache 라이선스 버전 2.0에 따라 라이선스가 부여됩니다.

전반적으로 AngularJS는 대규모, 고성능, 유지 관리가 쉬운 웹 애플리케이션을 구축하기위한 프레임 워크입니다.

핵심 기능

AngularJS의 핵심 기능은 다음과 같습니다.

  • Data-binding − 모델과 뷰 컴포넌트 간의 데이터 자동 동기화입니다.

  • Scope− 모델을 참조하는 객체입니다. 컨트롤러와 뷰 사이의 접착제 역할을합니다.

  • Controller − 특정 범위에 바인딩 된 JavaScript 함수입니다.

  • Services− AngularJS는 XMLHttpRequest를 만들기 위해 $ http와 같은 몇 가지 내장 서비스를 제공합니다. 이들은 앱에서 한 번만 인스턴스화되는 싱글 톤 객체입니다.

  • Filters − 이들은 배열에서 항목의 하위 집합을 선택하고 새 배열을 반환합니다.

  • Directives− 지시문은 요소, 속성, CSS 등과 같은 DOM 요소의 마커입니다. 이들은 새로운 사용자 정의 위젯 역할을하는 사용자 정의 HTML 태그를 만드는 데 사용할 수 있습니다. AngularJS에는 ngBind, ngModel 등과 같은 기본 제공 지시문이 있습니다.

  • Templates− 컨트롤러 및 모델의 정보가 포함 된 렌더링 된 뷰입니다. 단일 파일 (예 : index.html) 또는 partials를 사용하는 한 페이지의 여러보기가 될 수 있습니다 .

  • Routing −보기 전환 개념입니다.

  • Model View Whatever− MVW는 응용 프로그램을 모델,보기 및 컨트롤러라는 서로 다른 부분으로 나누기위한 설계 패턴으로, 각각의 책임이 다릅니다. AngularJS는 전통적인 의미에서 MVC를 구현하지 않고 오히려 MVVM (Model-View-ViewModel)에 더 가깝습니다. Angular JS 팀은 그것을 Model View Whatever라고 유머러스하게 언급합니다.

  • Deep Linking− 딥 링킹은 URL에 애플리케이션 상태를 인코딩하여 북마크 할 수 있도록합니다. 그런 다음 애플리케이션을 URL에서 동일한 상태로 복원 할 수 있습니다.

  • Dependency Injection − AngularJS에는 개발자가 애플리케이션을 쉽게 생성, 이해 및 테스트하는 데 도움이되는 내장 종속성 주입 하위 시스템이 있습니다.

개념

다음 다이어그램은 다음 장에서 자세히 논의 할 AngularJS의 몇 가지 중요한 부분을 보여줍니다.

AngularJS의 장점

AngularJS의 장점은-

  • 단일 페이지 응용 프로그램을 매우 깨끗하고 유지 관리 할 수있는 방식으로 만드는 기능을 제공합니다.

  • HTML에 데이터 바인딩 기능을 제공합니다. 따라서 사용자에게 풍부하고 반응이 빠른 경험을 제공합니다.

  • AngularJS 코드는 단위 테스트가 가능합니다.

  • AngularJS는 의존성 주입을 사용하고 관심사 분리를 사용합니다.

  • AngularJS는 재사용 가능한 구성 요소를 제공합니다.

  • AngularJS를 사용하면 개발자는 짧은 코드로 더 많은 기능을 얻을 수 있습니다.

  • AngularJS에서 뷰는 순수한 html 페이지이고 JavaScript로 작성된 컨트롤러가 비즈니스 처리를 수행합니다.

무엇보다도 AngularJS 애플리케이션은 Android 및 iOS 기반 휴대폰 / 태블릿을 포함한 모든 주요 브라우저 및 스마트 폰에서 실행할 수 있습니다.

AngularJS의 단점

AngularJS에는 많은 장점이 있지만 여기에 몇 가지 우려 사항이 있습니다.

  • Not Secure− JavaScript 전용 프레임 워크이기 때문에 AngularJS로 작성된 애플리케이션은 안전하지 않습니다. 애플리케이션을 안전하게 유지하려면 서버 측 인증 및 권한 부여가 필요합니다.

  • Not degradable − 애플리케이션 사용자가 JavaScript를 비활성화하면 기본 페이지를 제외하고는 아무것도 표시되지 않습니다.

AngularJS 지시어

AngularJS 프레임 워크는 크게 세 부분으로 나눌 수 있습니다.

  • ng-app −이 지시문은 AngularJS 애플리케이션을 정의하고 HTML에 연결합니다.

  • ng-model −이 지시문은 AngularJS 애플리케이션 데이터의 값을 HTML 입력 컨트롤에 바인딩합니다.

  • ng-bind −이 지시문은 AngularJS 애플리케이션 데이터를 HTML 태그에 바인딩합니다.