亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Angular4學習筆記之根模塊與Ng模塊

 更新時間:2017年09月09日 16:22:43   作者:小鐳Ra  
這篇文章主要介紹了Angular4學習筆記之根模塊與Ng模塊,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

根模塊 (root module)

每個應用都至少有一個根模塊用來引導并運行應用。根模塊通常命名為 AppModule。

示例 src/app/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 { }

imports 數(shù)組

注意:不要在 imports 數(shù)組中加入 NgModule 類型之外的類。

如果有兩個同名指令都叫做 HighlightDirective,我們只要在 import 時使用 as 關鍵字來為第二個指令創(chuàng)建個別名就可以了。

import {
 HighlightDirective as ContactHighlightDirective
} from './contact/highlight.directive';

關于 BrowserModule

每個瀏覽器中運行的應用都需要 @angular/platform-browser 里的 BrowserModule。 所以每個這樣的應用都在其根 AppModule 的 imports 數(shù)組中包含 BrowserModule。

NgIf 是在來自 @angular/common 的 CommonModule 中聲明的。

CommonModule 提供了很多應用程序中常用的指令,包括 NgIf 和 NgFor 等。

BrowserModule 導入了 CommonModule 并且重新導出了它。 最終的效果是:只要導入 BrowserModule 就自動獲得了 CommonModule 中的指令。

declarations 數(shù)組

你必須在一個 NgModule 類聲明每一個組件,否則瀏覽器控制臺會報錯。

不要在 declarations 添加組件、指令和管道以外的其他類型。

不要把 NgModel(或 FORMS_DIRECTIVES)加到 AppModule 元數(shù)據(jù)的 declarations 數(shù)據(jù)中!這些指令屬于 FormsModule。
組件、指令和管道只能屬于一個模塊。

永遠不要再次聲明屬于其它模塊的類。

bootstrap 數(shù)組

通過引導根 AppModule 來啟動應用。 在啟動過程中,其中一步是創(chuàng)建列在 bootstrap 數(shù)組的組件, 并將它們每一個都插入到瀏覽器的DOM中。
You launch the application by bootstrapping the root AppModule. Among other things, the bootstrapping process creates the component(s) listed in the bootstrap array and inserts each one into the browser DOM.

每個被引導的組件都是它自己的組件樹的根。 插入一個被引導的組件通常觸發(fā)一系列組件的創(chuàng)建并形成組件樹。
Each bootstrapped component is the base of its own tree of components. Inserting a bootstrapped component usually triggers a cascade of component creations that fill out that tree.

雖然你可以將多個組件樹插入到宿主頁面,但并不普遍。 大多數(shù)應用只有一個組件樹,它們引導單一根組件。
While you can put more than one component tree on a host web page, that's not typical. Most applications have only one component tree and they bootstrap a single root component.

根組件通常命名為 AppComponent。

在 main.ts 中引導

引導應用的方法很多。 它們?nèi)Q于你想如何編譯應用以及應用將在哪兒運行。

通過即時 (JIT) 編譯器動態(tài)引導

JIT, just-in-time

使用即時 (JIT) 編譯器動態(tài)編譯應用 src/main.ts

// The browser platform with a compiler
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';

// The app module
import { AppModule } from './app/app.module';

// Compile and launch the module
platformBrowserDynamic().bootstrapModule(AppModule);

使用預編譯器 (AOT) 進行靜態(tài)引導

AOT, ahead-of-time

靜態(tài)方案可以生成更小、啟動更快的應用,建議優(yōu)先使用它,特別是在移動設備或高延遲網(wǎng)絡下。

使用靜態(tài)選項,Angular 編譯器作為構(gòu)建流程的一部分提前運行,生成一組類工廠。它們的核心就是 AppModuleNgFactory。

引導預編譯的 AppModuleNgFactory:

// The browser platform without a compiler
import { platformBrowser } from '@angular/platform-browser';

// The app module factory produced by the static offline compiler
import { AppModuleNgFactory } from './app/app.module.ngfactory';

// Launch with the app module factory.
platformBrowser().bootstrapModuleFactory(AppModuleNgFactory);

說明:由于整個應用都是預編譯的,所以我們不用把 Angular 編譯器一起發(fā)到瀏覽器中,也不用在瀏覽器中進行編譯。

無論是 JIT 還是 AOT 編譯器都會從同一份 AppModule 源碼中生成一個 AppModuleNgFactory 類。 JIT 編譯器動態(tài)地在瀏覽器的內(nèi)存中創(chuàng)建這個工廠類。 AOT 編譯器把工廠輸出成一個物理文件,也就是我們在靜態(tài)版本 main.ts 中導入的那個。

通常,AppModule 不必關心它是如何被引導的。AppModule 會隨著應用而演化,但是 main.ts 中的引導代碼不會變。

Ng模塊 (NgModule)

特性模塊

特性模塊是帶有 @NgModule 裝飾器及其元數(shù)據(jù)的類,就像根模塊一樣。 特性模塊的元數(shù)據(jù)和根模塊的元數(shù)據(jù)的屬性是一樣的。

根模塊和特性模塊還共享著相同的執(zhí)行環(huán)境。 它們共享著同一個依賴注入器,這意味著某個模塊中定義的服務在所有模塊中也都能用。

它們在技術上有兩個顯著的不同點:

  1. 我們引導根模塊來啟動應用,但導入特性模塊來擴展應用。
  2. 特性模塊可以對其它模塊暴露或隱藏自己的實現(xiàn)。

特性模塊用來提供了內(nèi)聚的功能集合。 聚焦于應用的某個業(yè)務領域、用戶工作流、某個基礎設施(表單、HTTP、路由),或一組相關的工具集合。

雖然這些都能在根模塊中做,但特性模塊可以幫助我們把應用切分成具有特定關注點和目標的不同區(qū)域。

當前模塊不會繼承其它模塊中對組件、指令或管道的訪問權。根模塊與特性模塊的 imports 互不相干。如果某一個模塊要綁定到 [(ngModel)] 就必需導入 FormsModule。

總結(jié)

本章整理內(nèi)容較少,主要是詳細理解 Angular 模塊的概念、功能、關系。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Angularjs中數(shù)據(jù)綁定的實例詳解

    Angularjs中數(shù)據(jù)綁定的實例詳解

    這篇文章主要介紹了Angularjs中數(shù)據(jù)綁定的實例詳解的相關資料,這里提供簡單實例,大家可以參考下,希望通過本文可以掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-08-08
  • 解決angular 使用原生拖拽頁面卡頓及表單控件輸入延遲問題

    解決angular 使用原生拖拽頁面卡頓及表單控件輸入延遲問題

    這篇文章主要介紹了angular 中使用原生拖拽頁面卡頓及表單控件輸入延遲問題,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • 在AngularJs中設置請求頭信息(headers)的方法及不同方法的比較

    在AngularJs中設置請求頭信息(headers)的方法及不同方法的比較

    在AngularJs中有三種方式可以設置請求頭信息,文中對每種方法給大家介紹的非常詳細,選擇那種方式可以根據(jù)自己的需求,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-09-09
  • Angular 1.x個人使用的經(jīng)驗小結(jié)

    Angular 1.x個人使用的經(jīng)驗小結(jié)

    這篇文章主要給大家介紹了關于Angular 1.x個人使用的一些經(jīng)驗,屬于一些基礎入門教程,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • angular仿支付寶密碼框輸入效果

    angular仿支付寶密碼框輸入效果

    本篇文章主要介紹了angular仿支付寶密碼框輸入效果,詳細的介紹了使用ng寫一個密碼框格子支付模塊,具有一定的參考價值,有興趣的可以了解一下。
    2017-03-03
  • 淺談Angularjs link和compile的使用區(qū)別

    淺談Angularjs link和compile的使用區(qū)別

    下面小編就為大家?guī)硪黄獪\談Angularjs link和compile的使用區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • angularjs下拉框空白的解決辦法

    angularjs下拉框空白的解決辦法

    這篇文章主要為大家詳細介紹了angularjs下拉框空白的解決方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 手動初始化Angular的模塊與控制器

    手動初始化Angular的模塊與控制器

    本文主要介紹了手動初始化Angular的模塊與控制器的方法,具有一定的參考價值,下面跟著小編一起來看下吧
    2016-12-12
  • 詳解支持Angular 2的表格控件

    詳解支持Angular 2的表格控件

    本文主要對支持Angular2的表格控件進行詳細介紹。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • angular實現(xiàn)表單驗證及提交功能

    angular實現(xiàn)表單驗證及提交功能

    這篇文章主要為大家詳細介紹了angular實現(xiàn)表單驗證及提交功能的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02

最新評論