EmberJS-퀵 가이드
Ember.js는 무엇입니까?
Ember.js는 웹 애플리케이션 개발에 사용되는 오픈 소스, 무료 JavaScript 클라이언트 측 프레임 워크입니다. 데이터 관리 및 애플리케이션 흐름을 포함하는 완전한 솔루션을 제공함으로써 클라이언트 측 JavaScript 애플리케이션을 구축 할 수 있습니다.
Ember.js의 원래 이름은 SproutCore MVC 프레임 워크 였습니다. Yehuda Katz에 의해 개발되었으며 2011 년 12 월 에 처음 출시되었습니다 . Ember.js의 안정적인 릴리스는 2.10.0이며 2016 년 11 월 28 일에 릴리스되었습니다.
왜 Ember.js인가?
Ember.js의 사용을 이해하려면 다음 사항을 고려하십시오.
Ember.js는 MIT 라이선스에 따른 오픈 소스 JavaScript 프레임 워크입니다.
그것은 사용하여 새로운 결합 구 제공 HTMLBars 의 상위 집합 템플릿 엔진 Handerlbars 엔진을하는 주형.
렌더링 속도를 높이기 위해 Glimmer 렌더링 엔진 을 제공합니다 .
Ember 패턴을 개발 프로세스에 통합하고 개발자 생산성에 쉽게 집중 하는 명령 줄 인터페이스 유틸리티를 제공합니다 .
두 속성 간의 링크를 생성하는 데이터 바인딩 을 지원하며 한 속성이 변경되면 다른 속성이 새 값으로 업그레이드됩니다.
Ember.js의 기능
다음은 Ember.js의 가장 눈에 띄는 기능 중 일부입니다.
Ember.js는 재사용 및 유지 관리가 가능한 JavaScript 웹 애플리케이션을 만드는 데 사용됩니다.
Ember.js는 개발 모델의 핵심에 HTML 과 CSS 를 가지고 있습니다.
인스턴스 이니셜 라이저를 제공합니다.
경로는 URL 관리에 사용되는 Ember.js의 핵심 기능입니다.
Ember.js는 Ember 애플리케이션 디버깅을위한 Ember Inspector 도구를 제공 합니다.
Ember.js는 애플리케이션의 내용이 변경 될 경우 모델을 자동으로 업데이트하는 데 도움이되는 템플릿을 사용합니다.
시스템에서 Ember.js를 구성하는 것은 쉽습니다. Ember CLI (명령 줄 인터페이스) 유틸리티를 사용하여 Ember 프로젝트를 만들고 관리 할 수 있습니다. Ember CLI는 연결, 축소 및 버전 관리와 같은 다양한 종류의 애플리케이션 자산 관리를 처리하고 구성 요소, 경로 등을 생성하는 생성기를 제공합니다.
Ember CLI를 설치하려면 다음 종속성이 필요합니다.
Git− 파일의 변경 사항을 추적하기위한 오픈 소스 버전 관리 시스템입니다. 자세한 내용은 git 공식 웹 사이트를 확인하세요 . Ember는 Git을 사용하여 종속성을 관리합니다.
리눅스에 힘내 설치 :이 링크를 사용하여 Linux에서 망할 놈의 설치 -http://git-scm.com/download/linux
Mac에 Git 설치 :이 링크를 사용하여 Mac OS에 Git을 설치합니다.https://git-scm.com/download/mac
Linux에 Git 설치 :이 링크를 사용하여 Windows에 Git을 설치하십시오.https://git-scm.com/download/win
Node.js and npm− Node.js는 서버 측 및 네트워킹 애플리케이션 개발에 사용되는 오픈 소스입니다. JavaScript로 작성되었습니다. NPM은 프로젝트에서 종속성을 설치, 공유 및 관리하는 데 사용되는 노드 패키지 관리자입니다. Ember CLI는 Node.js 런타임과 npm을 사용하여 종속성을 가져옵니다.
Bower − HTML, CSS, JavaScript, 이미지 파일 등의 구성 요소를 관리하는 데 사용되며 npm을 사용하여 설치할 수 있습니다.
Watchman −이 선택적 종속성은 파일 또는 디렉토리를 감시하고 변경시 일부 작업을 실행하는 데 사용할 수 있습니다.
PhantomJS −이 선택적 종속성은 웹 페이지와 상호 작용하기 위해 브라우저 기반 단위 테스트를 실행하는 데 사용할 수 있습니다.
Ember CLI 설치
Ember CLI는 Ember 패턴을 개발 프로세스에 통합하고 개발자 생산성에 쉽게 초점을 맞 춥니 다. Ember.js 및 Ember 데이터로 Ember 앱을 만드는 데 사용됩니다.
아래 주어진 명령에서와 같이 npm을 사용하여 Ember를 설치할 수 있습니다-
npm install -g ember-cli
베타 버전을 설치하려면 다음 명령을 사용하십시오.
npm install -g [email protected]
Ember의 성공적인 설치를 확인하려면 다음 명령을 사용하십시오-
ember -v
위의 명령을 실행하면 다음과 같이 표시됩니다.
ember-cli: 2.10.1
node: 0.12.7
os: win32 ia32
Ember.js에는 다음과 같은 핵심 개념이 있습니다.
- Router
- Templates
- Models
- Components
라우터 및 경로 처리기
URL은 주소 표시 줄에 URL을 입력하여 앱을로드하고 사용자는 앱 내의 링크를 클릭합니다. Ember는 라우터를 사용하여 URL을 경로 핸들러에 매핑합니다. 라우터는 데이터를로드하고 템플릿을 표시하고 애플리케이션 상태를 설정하는 데 사용되는 경로에 기존 URL을 일치시킵니다.
Route 핸들러는 다음 작업을 수행합니다.
템플릿을 제공합니다.
템플릿에 액세스 할 수있는 모델을 정의합니다.
사용자가 앱의 특정 부분을 방문 할 권한이없는 경우 라우터는 새 경로로 리디렉션됩니다.
템플릿
템플릿은 최종 사용자를위한 강력한 UI입니다. Ember 템플릿은 Handlebars 템플릿 의 구문을 사용하는 응용 프로그램의 사용자 인터페이스 모양을 제공합니다 . 일반 HTML과 같은 프론트 엔드 애플리케이션을 빌드합니다. 또한 정규 표현식을 지원하고 표현식을 동적으로 업데이트합니다.
모델
경로 핸들러는 정보를 웹 서버에 유지하는 모델을 렌더링합니다. 데이터베이스에 저장된 데이터를 조작합니다. 모델은 Ember 데이터의 기능을 확장하는 간단한 클래스입니다. Ember Data는 Ember.js와 밀접하게 결합되어 데이터베이스에 저장된 데이터를 조작하는 라이브러리입니다.
구성품
구성 요소는 두 부분을 포함하는 사용자 인터페이스 동작을 제어합니다.
JavaScript로 작성된 템플릿
컴포넌트의 동작을 제공하는 JavaScript로 작성된 소스 파일입니다.
시스템에서 Ember.js를 쉽게 구성 할 수 있습니다. Ember.js의 설치 는 EmberJS 설치 장 에서 설명합니다 .
응용 프로그램 생성
Ember.js를 사용하여 하나의 간단한 앱을 만들어 보겠습니다. 먼저 응용 프로그램을 만드는 하나의 폴더를 만듭니다. 예를 들어 "emberjs-app"폴더를 만든 경우이 폴더로 이동합니다.
$ cd ~/emberjs-app
"emberjs = app"폴더 안에 새 명령을 사용하여 새 프로젝트를 만듭니다.
$ ember new demo-app
프로젝트를 생성 할 때 새 명령은 파일 및 디렉토리와 함께 다음 디렉토리 구조를 제공합니다.
|-- app
|-- bower_components
|-- config
|-- dist
|-- node_modules
|-- public
|-- tests
|-- tmp
|-- vendor
bower.json
ember-cli-build.js
package.json
README.md
testem.js
app − 모델, 루트, 구성 요소, 템플릿 및 스타일의 폴더와 파일을 지정합니다.
bower_components / bower.json− HTML, CSS, JavaScript, 이미지 파일 등의 구성 요소를 관리하는 데 사용되며 npm을 사용하여 설치할 수 있습니다. bower_components의 디렉토리는 모든 바우어의 구성 요소를 포함하고 bower.json은 엠버, 엠버 CLI 심과 QUnit으로 설치되는 종속성 목록이 포함되어 있습니다.
config− 여기에는 응용 프로그램의 설정을 구성하는 데 사용되는 environment.js 디렉토리가 포함되어 있습니다 .
dist − 앱을 빌드 할 때 배포되는 출력 파일을 포함합니다.
node_modules / package.json− NPM은 Node.js 용 노드 패키지 관리자로서 프로젝트에서 종속성을 설치, 공유 및 관리하는 데 사용됩니다. package.json 파일에는 응용 프로그램의 현재 npm 종속성이 포함되어 있으며 나열된 패키지는node_modules 예배 규칙서.
public − 여기에는 이미지, 글꼴 등과 같은 자산이 포함됩니다.
vendor − 자바 스크립트, CSS와 같은 프론트 엔드 의존성이 Bower go에 의해 제어되지 않는 디렉토리입니다.
tests / testem.js- 자동화 시험 폴더 검사 및 테스트 러너에 저장되어 testem 엠버의 CLI가 배치된다 testem.js .
tmp − Ember CLI의 임시 파일이 포함되어 있습니다.
ember-cli-build.js − Ember CLI를 사용하여 앱을 빌드하는 방법을 지정합니다.
응용 프로그램 실행
응용 프로그램을 실행하려면 새로 생성 된 프로젝트 디렉토리로 이동하십시오.
$ cd demo-app
우리는 새 프로젝트를 생성했으며 아래에 주어진 명령으로 실행할 준비가되었습니다.
$ ember server
이제 브라우저를 열고 http://localhost:4200/. 아래 이미지와 같이 Ember 환영 페이지가 나타납니다.
Ember.js에서 모든 개체는 Ember.Object에서 파생됩니다. 객체 지향 분석 및 설계 기법을object modeling. Ember.Object는 클래스 시스템을 사용하여 믹스 인 및 생성자 메서드와 같은 기능을 지원합니다. Ember는 Ember.Enumerable 인터페이스를 사용하여 JavaScript Array 프로토 타입을 확장하여 배열에 대한 관찰 변경 사항을 제공하고 서식 지정 및 지역화 메서드를 사용하여 String 프로토 타입 을 확장합니다 .
다음 표는 Ember.js의 다양한 유형의 객체 모델을 설명과 함께 나열합니다.
S. 아니. | 유형 및 설명 |
---|---|
1 | 클래스 및 인스턴스 클래스는 변수 및 함수 모음이있는 템플릿 또는 청사진이지만 인스턴스는 해당 클래스의 객체와 관련이 있습니다. Ember.Object의 extend () 메서드 를 사용하여 새 Ember 클래스를 만들 수 있습니다 . |
2 | 클래스 및 인스턴스 다시 열기 이것은 다시 정의하지 않고 클래스 구현을 업데이트하는 것입니다. |
삼 | 계산 된 속성 계산 된 속성은 함수를 속성으로 선언하고 Ember.js는 필요할 때 자동으로 계산 된 속성을 호출하고 하나 이상의 속성을 하나의 변수에 결합합니다. |
4 | 계산 된 속성 및 집계 데이터 계산 된 속성은 배열의 모든 항목에 액세스하여 값을 결정합니다. |
5 | 관찰자 관찰자는 계산 된 속성과 같은 속성을 관찰하고 계산 된 속성의 텍스트를 업데이트합니다. |
6 | 바인딩 바인딩은 Ember.js의 강력한 기능으로 두 속성 사이에 링크를 생성하고 속성 중 하나가 변경되면 다른 속성이 자동으로 업데이트됩니다. |
라우터는 URL을 일련의 템플릿으로 변환하고 애플리케이션의 상태를 나타내는 EmberJs의 핵심 기능입니다. Ember는 라우터를 사용하여 URL을 경로 처리기에 매핑합니다. 라우터는 현재 URL을 데이터로드, 템플릿 표시 및 애플리케이션 상태 설정에 사용되는 다른 경로와 일치시킵니다.
경로 처리기는 다음과 같은 일부 작업을 수행합니다.
템플릿을 제공합니다.
모델을 정의하고 템플릿에 액세스 할 수 있습니다.
사용자가 앱의 특정 부분을 방문 할 권한이없는 경우 라우터는 새 경로로 리디렉션됩니다.
다음 표는 Ember.js의 다양한 라우터를 설명과 함께 나열합니다.
S. 아니. | 유형 및 설명 |
---|---|
1 | 경로 정의 라우터는 현재 URL을 템플릿 표시, 데이터로드 및 애플리케이션 상태 설정을 담당하는 경로와 일치시킵니다. |
2 | 경로의 모델 지정 경로 모델을 지정하려면 모델의 데이터를 표시하는 템플릿이 필요합니다. |
삼 | 템플릿 렌더링 경로는 외부 템플릿을 화면에 렌더링하는 데 사용됩니다. |
4 | 리디렉션 요청 된 URL을 찾을 수 없을 때 사용자를 다른 페이지로 리디렉션하는 URL 리디렉션 메커니즘입니다. |
5 | 전환 방지 및 재시도 transition.abort () 및 transition.retry () 메소드를 취소하고 경로 전환시에, 각각의 전환을 시도 할 수있다. |
6 | 로드 / 오류 하위 상태 Ember 라우터는 경로를로드 할 때 발생하는 경로로드 및 오류에 대한 정보를 제공합니다. |
7 | 쿼리 매개 변수 검색어 매개 변수는 "?"의 오른쪽에 표시됩니다. 선택적 키-값 쌍으로 표시되는 URL에 표시합니다. |
8 | 비동기 라우팅 Ember.js 라우터에는 비동기 라우팅을 사용하여 애플리케이션 내에서 복잡한 비동기 논리를 처리 할 수있는 기능이 있습니다. |
템플릿은 여러 페이지에 걸쳐 표준 레이아웃 을 만드는 데 사용됩니다 . 템플릿을 변경하면 해당 템플릿을 기반으로하는 페이지가 자동으로 변경됩니다. 템플릿은 표준화 제어를 제공 합니다 .
아래 표는 템플릿에 대한 자세한 내용을 보여줍니다.
S. 아니. | 유형 및 설명 |
---|---|
1 | 핸들 바 기본 Handlebars 템플릿 라이브러리를 사용하면 정적 HTML 및 동적 콘텐츠를 포함하여 풍부한 사용자 인터페이스를 구축 할 수 있습니다. |
2 | 내장 도우미 도우미는 템플릿에 추가 기능을 제공하고 모델 및 구성 요소의 원시 값을 사용자에게 적합한 형식으로 수정합니다. |
삼 | 조건부 Ember.js는 프로그램의 흐름을 제어하는 데 도움이되는 두 가지 조건문을 정의합니다. |
4 | 항목 목록 표시 #each 도우미 를 사용하여 배열의 항목 목록을 표시 할 수 있습니다 . |
5 | 개체에 키 표시 # each-in 도우미를 사용하여 개체의 키를 표시 할 수 있습니다 . |
6 | 연결 {{링크에}} 구성 요소는 경로에 대한 링크를 만들 수 있습니다. |
7 | 행위 HTML 요소는 {{action}} 도우미 를 사용하여 클릭 가능하게 만들 수 있습니다 . |
8 | 입력 도우미 Ember.js에서 {{input}} 및 {{textarea}} 도우미를 사용하여 일반적인 양식 컨트롤을 만들 수 있습니다. |
9 | 개발 도우미 Handlebars 및 Ember의 일부 도우미를 사용하여 템플릿 개발을 더 쉽게 할 수 있습니다. |
10 | 헬퍼 작성 템플릿에 추가 기능을 추가하고 모델 및 구성 요소의 원시 값을 사용자에게 적합한 형식으로 변환 할 수 있습니다. |
Ember.js 구성 요소는 W3C 웹 구성 요소 사양을 사용하며 진정한 캡슐화 UI 위젯을 제공합니다. 여기에는 템플릿 , Shadow DOM 및 사용자 정의 요소 와 같은 세 가지 주요 사양이 포함되어 있습니다 . 구성 요소는 일반 문자열 대신 경로 이름이 있고 "components /"접두사가 붙은 data-template-name 내에서 선언됩니다.
다음 표는 액션의 액션 이벤트를 나열합니다-
S. 아니. | 액션 이벤트 및 설명 |
---|---|
1 | 구성 요소 정의 Ember.js에서 구성 요소를 쉽게 정의 할 수 있으며 각 구성 요소에는 이름에 대시가 있어야합니다. |
2 | 구성 요소 수명주기 구성 요소 수명주기는 구성 요소 수명의 특정 시간에 코드를 실행하기 위해 일부 메서드를 사용합니다. |
삼 | 구성 요소에 속성 전달 구성 요소는 템플릿 범위에서 직접 속성에 액세스하지 않습니다. 따라서 컴포넌트 감속시 속성을 선언하면됩니다. |
4 | 구성 요소에 내용 래핑 템플릿을 사용하여 구성 요소의 내용을 래핑 할 수 있습니다. |
5 | 구성 요소 요소 사용자 지정 JavaScript에서 Ember.Component 의 하위 클래스를 사용하여 속성, 클래스 이름과 같은 구성 요소의 요소를 사용자 지정할 수 있습니다 . |
6 | 블록 매개 변수 사용 구성 요소에 전달 된 속성은 결과를 블록 식으로 반환 할 수 있습니다. |
7 | 이벤트 처리 더블 클릭, 호버링, 키 누름 등과 같은 사용자 이벤트는 이벤트 핸들러로 처리 할 수 있습니다. 이렇게하려면 이벤트 이름을 구성 요소의 메서드로 적용합니다. |
8 | 액션으로 변경 트리거 구성 요소는 작업을 사용하여 변경 사항을 트리거하고 이벤트와 통신 할 수 있습니다. |
Model은 Ember 데이터의 기능을 확장하는 클래스입니다. 사용자가 페이지를 새로 고치면 페이지의 내용이 모델로 표시되어야합니다. Ember.js에서 모든 경로에는 관련 모델이 있습니다. 이 모델은 응용 프로그램의 성능을 향상시키는 데 도움이됩니다. Ember 데이터는 서버에 저장된 데이터를 조작하고 socket.io 및 Firebase 또는 WebSockets와 같은 스트리밍 API 와도 쉽게 작동합니다.
핵심 개념
- Store
- Models
- Records
- Adapter
- Caching
저장
저장소는 애플리케이션에서 사용할 수있는 모든 레코드의 중앙 저장소이자 캐시입니다. 경로와 컨트롤러는 애플리케이션의 저장된 데이터에 액세스 할 수 있습니다. DS.Store는 전체 개체간에 데이터를 공유하기 위해 자동으로 생성됩니다.
import Ember from 'ember';
export default Ember.Route.extend ({
model() {
return this.store.find();
}
});
모델
Model은 다른 개체와의 관계를 지정하는 Ember 데이터의 기능을 확장하는 클래스입니다. 사용자가 페이지를 새로 고치면 페이지의 내용이 모델로 표시되어야합니다.
import DS from 'ember-data';
export default DS.Model.extend ({
owner: DS.attr(),
city: DS.attr()
});
기록
레코드는 정보가 포함 된 모델의 인스턴스이며 서버에서로드되며 모델 유형 및 ID로 레코드를 식별 할 수 있습니다 .
//It finds the record of type 'person' and an 'ID' of 1
this.get('store').findRecord('person', 1); // => { id: 1, name: 'steve-buscemi' }
어댑터
어댑터는 Ember에서 요청 된 레코드를 특정 서버 백엔드에 대한 적절한 호출로 변환하는 역할을하는 객체입니다. 예를 들어 ID가 1 인 사람을 찾으려면 Ember는 HTTP를 / person / 1 로 사용하여 URL을로드합니다 .
캐싱
레코드는 저장소에서 자동으로 캐시 할 수 있으며 두 번째로 서버에서 레코드를로드 할 때 동일한 개체 인스턴스를 반환합니다. 이렇게하면 응용 프로그램의 성능이 향상되고 응용 프로그램 UI가 가능한 한 빨리 사용자에게 표시됩니다.
다음 표는 모델에 대한 세부 정보를 나열합니다.
S. 아니. | 모델 방법 및 설명 |
---|---|
1 | 모델 정의 Model은 Ember 데이터의 기능을 확장하는 간단한 클래스입니다. |
2 | 기록 찾기 Ember 데이터 저장소를 사용하여 레코드를 검색 할 수 있습니다. |
삼 | 레코드 생성 및 삭제 모델의 인스턴스에서 레코드를 생성하고 삭제할 수 있습니다. |
4 | 관계 Ember.js는 모델이 서로 관련되는 방식을 지정하는 관계 유형을 제공합니다. |
5 | 레코드를 상점으로 밀어 넣기 애플리케이션에서 레코드를 요청하지 않고 레코드를 상점 캐시로 푸시 할 수 있습니다. |
6 | 메타 데이터 처리 메타 데이터는 레코드를 사용하는 대신 특정 모델 또는 유형에 사용되는 데이터입니다. |
7 | 어댑터 사용자 정의 Ember.js 어댑터는 URL 형식 및 REST API 헤더와 같은 백엔드 데이터 저장소에서 데이터가 유지되는 방식을 지정합니다. |
Ember는 NPM 용 package.json 및 Bower 용 bower.json 에 정의 된 종속성을 관리하기 위해 NPM 및 Bower를 사용합니다 . 예를 들어, Ember 앱을 개발하는 동안 Ember가 설치하지 않은 스타일 시트에 대해 SASS를 설치해야 할 수 있습니다. 이를 수행하려면 재사용 가능한 라이브러리를 공유 하기 위해 Ember 애드온 을 사용하십시오 . CSS 프레임 워크 또는 JavaScript datepicker 종속성을 설치하려면 Bower 패키지 관리자를 사용하십시오.
애드온
엠버 CLI는 다음 명령을 사용하여 엠버 부가 기능을 설치하는 데 사용할 수 있습니다 -
ember install ember-cli-sass
타다 남은 명령은 설치 각각의 구성 파일에 대한 모든 종속성을 저장합니다.
나무 그늘
HTML, CSS, JavaScript 또는 이미지 파일의 구성 요소를 관리하는 웹용 패키지 관리자입니다. 기본적으로 모든 패키지를 유지 및 모니터링하고 새 업데이트를 검사합니다. Ember CLI 프로젝트의 루트에 배치 된 애플리케이션을 추적하기 위해 구성 파일 bower.json 을 사용합니다 .
다음 명령을 사용하여 프로젝트 종속성을 설치할 수 있습니다-
bower install <dependencies> --save
자산
Addon 또는 Bower 패키지로 사용할 수없는 프로젝트 의 vendor / 폴더에 타사 JavaScript를 배치하고 프로젝트의 public / 폴더에 robots.txt, favicon 등과 같은 자체 자산을 배치 할 수 있습니다 . Ember 앱을 개발하는 동안 Ember가 설치하지 않은 종속성은 매니페스트 파일 ember-cli-build.js 를 사용하여 포함해야합니다 .
AMD JavaScript 모듈
자산 경로를 첫 번째 인수로 제공하고 모듈 및 내보내기 목록을 두 번째 인수로 제공 할 수 있습니다. 이러한 자산을 ember-cli-build.js 매니페스트 파일에 다음과 같이 포함 할 수 있습니다.
app.import('bower_components/ic-ajax/dist/named-amd/main.js', {
exports: {
'ic-ajax': [
'default',
'defineFixture',
'lookupFixture',
'raw',
'request'
]
}
});
환경 특정 자산
객체를 환경 이름 인 첫 번째 매개 변수로 정의하여 서로 다른 자산을 서로 다른 환경에서 사용할 수 있으며 객체의 값은 해당 환경에서 자산으로 사용해야합니다. 에서 엠버-CLI가-build.js 매니페스트 파일을, 당신은 포함 할 수 있습니다 -
app.import ({
development: 'bower_components/ember/ember.js',
production: 'bower_components/ember/ember.prod.js'
});
기타 자산
모든 자산이 public / 폴더에 배치되면 dist / 디렉토리에 복사됩니다. 예를 들어 public / images / favicon.ico 폴더에 있는 favicon을 복사하면 dist / images / favicon.ico 디렉토리에 복사됩니다 . 타사 자산은 vendor / 폴더 에 수동으로 추가 하거나 import () 옵션을 통해 Bower 패키지 관리자를 사용하여 추가 할 수 있습니다 . import () 옵션 을 사용하여 추가되지 않은 자산 은 최종 빌드에 표시되지 않습니다.
예를 들어 자산을 dist / 폴더 로 가져 오는 다음 코드 줄을 고려하십시오 .
app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf');
위의 코드 줄은 dist / font-awesome / fonts / fontawesomewebfont.ttf에 글꼴 파일을 생성합니다 . 위의 파일을 아래와 같이 다른 경로에 배치 할 수도 있습니다.
app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf', {
destDir: 'assets'
});
dist / assets / fontawesome-webfont.ttf 의 글꼴 파일을 복사합니다 .
Ember 애플리케이션은 애플리케이션 빌드에 도움이되는 객체를 선언하고 구성하는 Ember.Application 클래스를 사용하여 확장 할 수 있습니다 .
응용 프로그램은 실행 중 Ember.ApplicationInstance 클래스를 생성하며, 이는 해당 측면을 관리하는 데 사용되며 인스턴스화 된 개체의 소유자 역할을합니다. 간단히 말해 Ember.Application 클래스는 응용 프로그램을 정의하고 Ember.ApplicationInstance 클래스 는 해당 상태를 관리합니다.
다음 표는 모델에 대한 자세한 내용을 나열합니다.
S. 아니. | 모델 방법 및 설명 |
---|---|
1 | 의존성 주입 한 개체의 종속성을 다른 개체에 제공하고 Ember 애플리케이션에서 개체와 종속성 클래스를 선언하고 인스턴스화하는 데 사용하는 프로세스입니다. |
2 | 이니셜 라이저 이니셜 라이저는 응용 프로그램이 부팅 될 때 구성하는 데 사용됩니다. |
삼 | 서비스 서비스는 응용 프로그램의 다른 부분에서 사용할 수있는 Ember 개체입니다. |
4 | 런 루프 대부분의 애플리케이션 내부 코드가 발생하는 영역입니다. |
Ember.js는 애플리케이션의 환경을 관리하기 위해 구성 할 수 있습니다. Ember.js 구성에는 다음 주제가 포함됩니다.
S. 아니. | 방법 및 설명 구성 |
---|---|
1 | 앱 및 Ember CLI 구성 애플리케이션의 환경을 관리하기 위해 Ember 앱 및 CLI를 구성 할 수 있습니다. |
2 | 프로토 타입 확장 비활성화 및 URL 유형 지정 프로토 타입 확장은 EXTEND_PROTOTYPES 플래그를 false 로 설정 하고 Ember 라우터 옵션을 사용하여 URL 유형을 지정하여 비활성화 할 수 있습니다. |
삼 | 응용 프로그램 및 기능 플래그 포함 루트 요소를 변경하여 기존 페이지에 애플리케이션을 임베드 할 수 있으며 프로젝트 구성에 따라 기능 플래그를 활성화 할 수 있습니다. |
Ember inspector는 Ember 애플리케이션을 디버깅하는 데 사용되는 브라우저 애드온입니다. Ember 검사관은 다음 주제를 포함합니다-
S. 아니. | Ember 검사관 방법 및 설명 |
---|---|
1 | 인스펙터 설치 Ember 검사기를 설치하여 애플리케이션을 디버깅 할 수 있습니다. |
2 | 개체 검사기 Ember 인스펙터는 Ember 객체와 상호 작용할 수 있습니다. |
삼 | 뷰 트리 보기 트리는 애플리케이션의 현재 상태를 제공합니다. |
4 | 경로, 데이터 탭 및 라이브러리 정보 검사 검사자가 정의한 애플리케이션 경로 목록을 볼 수 있으며 데이터 탭은 모델 유형 목록을 표시하는 데 사용됩니다. |
5 | 약속 디버깅 Ember 검사관은 상태에 따라 약속을 제공합니다. |
6 | 개체 검사 및 렌더링 성능 컨테이너를 사용하여 개체 인스턴스를 검사하고 렌더링 성능 옵션을 사용하여 응용 프로그램의 렌더링 시간을 계산합니다. |