VueJS-개요
VueJS인터랙티브 웹 인터페이스를 개발하는 데 사용되는 오픈 소스 프로그레시브 JavaScript 프레임 워크입니다. 웹 개발을 단순화하는 데 사용되는 유명한 프레임 워크 중 하나입니다. VueJS는 뷰 레이어에 중점을 둡니다. 문제없이 프런트 엔드 개발을 위해 대규모 프로젝트에 쉽게 통합 할 수 있습니다.
VueJS 설치는 시작하기가 매우 쉽습니다. 모든 개발자는 시간에 따라 대화 형 웹 인터페이스를 쉽게 이해하고 구축 할 수 있습니다. VueJS는 Google의 전 직원 인 Evan You가 만들었습니다. VueJS의 첫 번째 버전은 2014 년 2 월에 출시되었습니다. 최근 GitHub에서 64,828 개의 별을 기록하여 매우 인기가 있습니다.
풍모
다음은 VueJS에서 사용할 수있는 기능입니다.
가상 DOM
VueJS는 React, Ember 등과 같은 다른 프레임 워크에서도 사용되는 가상 DOM을 사용합니다. 변경 사항은 DOM에 적용되지 않고 대신 JavaScript 데이터 구조의 형태로 존재하는 DOM의 복제본이 생성됩니다. . 변경 사항이있을 때마다 JavaScript 데이터 구조가 변경되고 후자는 원래 데이터 구조와 비교됩니다. 그런 다음 최종 변경 사항이 실제 DOM으로 업데이트되고 사용자가 변경하는 것을 볼 수 있습니다. 이것은 최적화 측면에서 좋으며 비용이 적게 들고 변경이 더 빠른 속도로 이루어질 수 있습니다.
데이터 바인딩
데이터 바인딩 기능은 HTML 속성에 값을 조작하거나 할당하고, 스타일을 변경하고, 바인딩 지시문을 사용하여 클래스를 할당하는 데 도움이됩니다. v-bind VueJS에서 사용할 수 있습니다.
구성품
컴포넌트는 HTML에서 재사용 할 수있는 사용자 정의 요소를 만드는 데 도움이되는 VueJS의 중요한 기능 중 하나입니다.
이벤트 처리
v-on VueJS에서 이벤트를 수신하기 위해 DOM 요소에 추가 된 속성입니다.
애니메이션 / 전환
VueJS는 HTML 요소가 DOM에서 추가 / 업데이트 또는 제거 될 때 전환을 적용하는 다양한 방법을 제공합니다. VueJS에는 전환 효과를 위해 요소를 감싸 야하는 내장 전환 구성 요소가 있습니다. 타사 애니메이션 라이브러리를 쉽게 추가 할 수 있으며 인터페이스에 더 많은 상호 작용을 추가 할 수도 있습니다.
계산 된 속성
이것은 VueJS의 중요한 기능 중 하나입니다. UI 요소의 변경 사항을 듣고 필요한 계산을 수행하는 데 도움이됩니다. 이를 위해 추가 코딩이 필요하지 않습니다.
템플릿
VueJS는 DOM을 Vue 인스턴스 데이터와 바인딩하는 HTML 기반 템플릿을 제공합니다. Vue는 템플릿을 가상 DOM Render 함수로 컴파일합니다. 렌더링 함수의 템플릿을 사용할 수 있으며이를 위해 템플릿을 렌더링 함수로 대체해야합니다.
지시어
VueJS에는 프런트 엔드에서 다양한 작업을 수행하는 데 사용되는 v-if, v-else, v-show, v-on, v-bind 및 v-model과 같은 기본 제공 지시문이 있습니다.
감시자
감시자는 변경되는 데이터에 적용됩니다. 예를 들어, 입력 요소를 형성하십시오. 여기에서는 추가 이벤트를 추가 할 필요가 없습니다. Watcher는 모든 데이터 변경 사항을 처리하여 코드를 간단하고 빠르게 만듭니다.
라우팅
페이지 간 탐색은 vue-router를 사용하여 수행됩니다.
경량
VueJS 스크립트는 매우 가볍고 성능도 매우 빠릅니다.
Vue-CLI
VueJS는 vue-cli 명령 줄 인터페이스를 사용하여 명령 줄에 설치할 수 있습니다. vue-cli를 사용하여 프로젝트를 쉽게 빌드하고 컴파일하는 데 도움이됩니다.
다른 프레임 워크와의 비교
이제 VueJS를 React, Angular, Ember, Knockout 및 Polymer와 같은 다른 프레임 워크와 비교해 보겠습니다.
VueJS v / s React
Virtual DOM
Virtual DOM은 DOM 트리의 가상 표현입니다. 가상 DOM을 사용하면 실제 DOM과 동일한 JavaScript 객체가 생성됩니다. DOM을 변경해야 할 때마다 새 JavaScript 객체가 생성되고 변경됩니다. 나중에 두 JavaScript 객체가 비교되고 최종 변경 사항이 실제 DOM에서 업데이트됩니다.
VueJS와 React는 둘 다 가상 DOM을 사용하므로 더 빠릅니다.
Template v/s JSX
VueJS는 html, js 및 css를 별도로 사용합니다. 초보자가 VueJS 스타일을 이해하고 채택하는 것은 매우 쉽습니다. VueJS에 대한 템플릿 기반 접근 방식은 매우 쉽습니다.
React는 jsx 접근 방식을 사용합니다. 모든 것이 ReactJS 용 JavaScript입니다. HTML과 CSS는 모두 JavaScript의 일부입니다.
Installation Tools
React 사용 create react app 그리고 VueJS는 vue-cli /CDN/npm. 둘 다 사용하기가 매우 쉽고 프로젝트는 모든 기본 요구 사항으로 설정됩니다. React는 빌드를 위해 웹팩이 필요하지만 VueJS는 그렇지 않습니다. cdn 라이브러리를 사용하여 jsfiddle 또는 codepen의 어느 곳에서나 VueJS 코딩으로 시작할 수 있습니다.
Popularity
React는 VueJS보다 인기가 있습니다. React의 직업 기회는 VueJS 그 이상입니다. React, 즉 Facebook에는 더 인기있는 이름이 있습니다. React는 JavaScript의 핵심 개념을 사용하므로 JavaScript의 모범 사례를 사용합니다. React로 작업하는 사람은 모든 JavaScript 개념에 대해 확실히 잘할 것입니다.
VueJS는 개발 프레임 워크입니다. 현재 VueJS의 취업 기회는 React에 비해 적습니다. 설문 조사에 따르면 많은 사람들이 VueJS에 적응하고 있으며 이는 React 및 Angular에 비해 더 인기가 있습니다. VueJS의 다양한 기능에 대해 작업하는 좋은 커뮤니티가 있습니다. vue-router는 정기적 인 업데이트를 통해이 커뮤니티에서 관리합니다.
VueJS는 Angular와 React에서 좋은 부분을 가져와 강력한 라이브러리를 구축했습니다. VueJS는 경량 라이브러리로 인해 React / Angular에 비해 훨씬 빠릅니다.
VueJS 대 Angular
Similarities
VueJS는 Angular와 많은 유사점을 가지고 있습니다. v-if, v-for와 같은 지시문은 Angular의 ngIf, ngFor와 거의 유사합니다. 둘 다 프로젝트 설치 및 빌드를위한 명령 줄 인터페이스가 있습니다. VueJS는 Vue-cli를 사용하고 Angular는 angular-cli를 사용합니다. 둘 다 양방향 데이터 바인딩, 서버 측 렌더링 등을 제공합니다.
Complexity
Vuejs는 배우고 시작하기가 매우 쉽습니다. 앞서 논의했듯이 초보자는 VueJS의 CDN 라이브러리를 가져 와서 codepen 및 jsfiddle에서 시작할 수 있습니다.
Angular의 경우 설치를위한 일련의 단계를 거쳐야하며 초보자가 Angular를 시작하는 것은 거의 어렵지 않습니다. 핵심 JavaScript 배경에서 오는 사람들에게는 어려운 코딩에 TypeScript를 사용합니다. 그러나 Java 및 C # 배경에 속하는 사용자는 배우는 것이 더 쉽습니다.
Performance
성능을 결정하는 것은 사용자에게 달려 있습니다. VueJS 파일 크기는 Angular보다 훨씬 가볍습니다. 프레임 워크 성능 비교는 다음 링크에서 제공됩니다.http://stefankrause.net/js-frameworks-benchmark4/webdriver-ts/table.html
Popularity
현재 Angular는 VueJS보다 더 많이 사용됩니다. 많은 조직에서 Angular를 사용하여 매우 인기가 있습니다. Angular에서 경험 한 후보자에게도 취업 기회가 더 많습니다. 그러나 VueJS는 시장에서 자리를 차지하고 있으며 Angular 및 React의 좋은 경쟁자로 간주 될 수 있습니다.
Dependencies
Angular는 많은 내장 기능을 제공합니다. 필요한 모듈을 가져 와서 시작해야합니다 (예 : @ angular / animations, @ angular / form).
VueJS는 Angular와 같은 모든 내장 기능을 가지고 있지 않으며이를 작동하려면 타사 라이브러리에 의존해야합니다.
Flexibility
VueJS는 문제없이 다른 큰 프로젝트와 쉽게 병합 할 수 있습니다. Angular는 다른 기존 프로젝트 작업을 시작하기가 쉽지 않습니다.
Backward Compatibility
AngularJS, Angular2 및 이제 Angular4가 있습니다. AngularJS와 Angular2는 큰 차이가 있습니다. AngularJS에서 개발 한 프로젝트 애플리케이션은 핵심적인 차이점 때문에 Angular2로 변환 할 수 없습니다.
VueJS의 최신 버전은 2.0이며 이전 버전과의 호환성이 좋습니다. 매우 이해하기 쉬운 좋은 문서를 제공합니다.
Typescript
Angular는 코딩에 TypeScript를 사용합니다. Angular를 시작하려면 사용자가 Typescript에 대한 지식이 있어야합니다. 그러나 cdn 라이브러리를 사용하여 jsfiddle 또는 codepen의 어느 곳에서나 VueJS 코딩으로 시작할 수 있습니다. 우리는 시작하기 매우 쉬운 표준 JavaScript로 작업 할 수 있습니다.
VueJS 대 Ember
Similarities
Ember는 Ember 프로젝트를위한 간편한 설치 및 컴파일을 위해 Ember 명령 줄 도구, 즉 ember-cli를 제공합니다.
VueJS에는 프로젝트를 시작하고 빌드하기위한 명령 줄 도구 vue-cli도 있습니다.
둘 다 라우터, 템플릿 및 구성 요소와 같은 기능을 가지고있어 UI 프레임 워크처럼 매우 풍부합니다.
Performance
VueJS는 Ember에 비해 더 나은 성능을 제공합니다. Ember는 가상 DOM을 사용하는 VueJS 및 React와 유사한 개념 인 re-render 성능을 개선하기 위해 glimmer 렌더링 엔진을 추가했습니다. 그러나 VueJS는 Ember와 비교할 때 더 나은 성능을 제공합니다.
VueJS v / s 녹아웃
Knockout은 우수한 브라우저 지원을 제공합니다. IE의 하위 버전에서는 지원되는 반면 VueJS는 IE8 이하에서는 지원되지 않습니다. 녹아웃 개발은 시간이 지남에 따라 느려졌습니다. 최근에는 같은 것에 대한 인기가별로 없습니다.
반면 VueJS는 정기적 인 업데이트를 제공하는 Vue 팀과 함께 인기를 얻기 시작했습니다.
VueJS v / s 폴리머
폴리머 라이브러리는 Google에서 개발했습니다. Google I / O, Google Earth, Google Play Music 등과 같은 많은 Google 프로젝트에서 사용됩니다. VueJS와 유사한 데이터 바인딩 및 계산 된 속성을 제공합니다.
Polymer 사용자 지정 요소 정의는 일반 JavaScript / CSS, 요소 속성, 수명주기 콜백 및 JavaScript 메서드로 구성됩니다. 이에 비해 VueJS는 JavaScript / html 및 CSS를 쉽게 사용할 수 있습니다.
Polymer는 웹 구성 요소 기능을 사용하며 이러한 기능을 지원하지 않는 브라우저 용 폴리 필이 필요합니다. VueJS에는 이러한 종속성이 없으며 IE9 +의 모든 브라우저에서 제대로 작동합니다.