成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

從安裝認(rèn)識(shí)Angular 2

xietao3 / 1545人閱讀

摘要:首先,要確認(rèn)安裝了,并且創(chuàng)建了目錄并執(zhí)行初始化。想必看見上面的那么多包會(huì)一臉懵逼,沒關(guān)系,我第一眼看見這些的那刻,和你現(xiàn)在的表情一樣,下面在適當(dāng)?shù)臅r(shí)候我會(huì)逐個(gè)解釋的,你只需要相信我上面的包都是跑所必須的,缺一不可。

關(guān)于介紹,只說一句:Angular 2是一個(gè)強(qiáng)大、全面、龐大的MVVM框架。

安裝

安裝,也算是一個(gè)坎,因?yàn)槟阈枰惭b一大堆東西,卻不知道每個(gè)東西是做什么的,盡管有Angular-cli全家桶,但是個(gè)人覺得:一開始學(xué)就安裝全家桶,就像你直接用自動(dòng)擋學(xué)開車一樣,雖然上手快,但還是有些弊端的……

總之,我個(gè)人更傾向從底層學(xué)起。

首先,要確認(rèn)安裝了NodeJS,并且創(chuàng)建了目錄并執(zhí)行npm init初始化。

npm i -S @angular/core @angular/common @angular/compiler @angular/platform-browser @angular/platform-browser @angular/platform-browser-dynamic rxjs core-js zone.js@^0.7.2

想必看見上面的那么多包會(huì)一臉懵逼,沒關(guān)系,我第一眼看見這些的那刻,和你現(xiàn)在的表情一樣,下面在適當(dāng)?shù)臅r(shí)候我會(huì)逐個(gè)解釋的,你只需要相信我:上面的包都是跑Hello World所必須的,缺一不可。我們先盡快跑起可愛的Hello World。

我是2017年3月20日安裝的,各版本號(hào)如下:

需要額外說明一下的是zone.js這個(gè)庫,這對(duì)于Angular 2來說是個(gè)比較重要的庫,可以看到我上面的安裝命令里的最后一項(xiàng),zone.js@^0.7.2, 它是取代臟檢查的一個(gè)很重要的庫,用于解決異步操作,這里就不詳述了。

Anyway,如果安裝這個(gè)庫的時(shí)候不帶版本號(hào),它會(huì)報(bào)出以下錯(cuò)誤。有心折騰的小伙伴盡管試試~

npm WARN @angular/[email protected] requires a peer of zone.js@^0.7.2 but none was installed.

OK,我們安裝完運(yùn)行時(shí)依賴了,現(xiàn)在安裝開發(fā)依賴。

npm i -D webpack webpack-dev-server typescript ts-loader @types/[email protected]

看上面的@types/[email protected],是的,這是另一個(gè)坑,我默認(rèn)安裝的最新版0.9.37會(huì)報(bào)錯(cuò),必須降低版本,在Github這里給出了答案。愿意折騰的小伙伴盡管試試。

寫配置文件

OK,我們現(xiàn)在開始編寫配置文件

我們現(xiàn)在根目錄配置webpack.config.js,沒有它就沒法打包了!

// webpack.config.js
module.exports = {
  // 入口文件
  entry: "./src/main.ts",
  // 輸出目錄 
  output: {
    filename: "dist/bundle.js"
  },
  // 聲明解析上述格式的組件
  module: {
    loaders: [
      { test: /.ts$/, loader: "ts-loader" }
    ]
  }
};

然后是typescript的配置,畢竟我們的程序是用ts寫的。這個(gè)配置文件就不講解了,因?yàn)榛久總€(gè)項(xiàng)目的配置都完全一樣。

{
  "compilerOptions": {
    "target": "es5",
    "module": "commonjs",
    "moduleResolution": "node",
    "sourceMap": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "removeComments": false,
    "noImplicitAny": true,
    "suppressImplicitAnyIndexErrors": true,
    "typeRoots": [
      "./node_modules/@types/"
    ]
  },
  "compileOnSave": true,
  "exclude": [
    "node_modules"
  ]
}

我們?cè)偌右粋€(gè)index.html文件,你總要有個(gè)頁面看效果是不是?




    
    
    
    Angular 2


    加載中……
    


編寫Hello World

我們先創(chuàng)建一個(gè)文件夾叫src, 源碼都會(huì)被放進(jìn)這個(gè)文件夾里,現(xiàn)在我們?cè)賱?chuàng)建一個(gè)main.ts文件,粘貼以下代碼,這是Typescript的寫法,看不懂的話就用心看注釋:

import "core-js";
import "zone.js";
import {Component, NgModule} from "@angular/core";

import {platformBrowserDynamic} from "@angular/platform-browser-dynamic";
import {BrowserModule} from "@angular/platform-browser";

@Component({
    selector: "hello-world",
    template: `

Hello World

` }) class AppComponent { } @NgModule({ declarations: [AppComponent], imports: [BrowserModule], bootstrap: [AppComponent] }) class AppModule { } platformBrowserDynamic() .bootstrapModule(AppModule);

現(xiàn)在需要?jiǎng)?chuàng)建的文件都創(chuàng)建完了,怕路徑搞錯(cuò)了,來貼張圖:

OK,我們來逐行講解

首先是import的導(dǎo)入部分。

core-js - 為全局上下文(window)打的補(bǔ)丁,提供了ES2015(ES6)的很多基礎(chǔ)特性。主要是提供es6-shim,雖然Typescript是ES6的超集,但畢竟ES6才是Javascript的正根,Typescript還是不得不向著ES6靠攏,如Promise及Generator這種ES6的專有特性,ts無法轉(zhuǎn)譯。

zone.js - 用來幫助處理瀏覽器異步事件的工具庫,Angular2的變化檢測(cè)機(jī)制基于這個(gè)庫實(shí)現(xiàn)的。

{Component, NgModule} - 這兩個(gè)是Angular 2自己定義好的修飾器,或者叫裝飾器,Component是組件,一個(gè)或多個(gè)組件可以組成一個(gè)模塊,模塊就是NgModule。

@angular/core - 我們看到組件和模塊都是來自于這個(gè)包,angular/core是框架中的核心模塊,每一個(gè)應(yīng)用都需要它。 包括所有的裝飾器、指令、變化監(jiān)測(cè)、依賴注入、渲染等核心功能,以及組件生命周期鉤子。

{platformBrowserDynamic} - 這是動(dòng)態(tài)引導(dǎo),用于將你寫的所有程序編譯的組件,編譯完后才能啟動(dòng)應(yīng)用并渲染界面,可以說是打包前的最后一步,該組件來自于angular/platform-browser-dynamic。此外,還有個(gè)靜態(tài)引導(dǎo),名曰{platformBrowser},來自于angular/platform-browser
二者的區(qū)別是:動(dòng)態(tài)引導(dǎo)是在瀏覽器執(zhí)行編譯,靜態(tài)引導(dǎo)則省掉了瀏覽器編譯的這一步,體積更小、速度更快,直接可以啟動(dòng)應(yīng)用。相當(dāng)高深的說!

{BrowserModule} - 這是在瀏覽器運(yùn)行時(shí)的一些工具庫,將某些模塊打包導(dǎo)出,總之是必不可少的。@angular/platform-browser - 與DOM和瀏覽器相關(guān)的每樣?xùn)|西,特別是幫助往DOM中渲染的那部分。

帶有platform字樣的包,包含的都是引導(dǎo)啟動(dòng)的相關(guān)工具。

呃……我們終于可以講解正式的代碼了。

@Component({
    selector: "hello-world",
    template: `

Hello World

` }) class AppComponent { }

這段代碼的意思是:我現(xiàn)在要解析一個(gè)組件了。
它的名字叫hello-world,或者說叫,這個(gè)組件是個(gè)類哦,它的類名叫AppComponent。

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

這段代碼的意思是:我現(xiàn)在要解析一個(gè)模塊了。
declarations - 導(dǎo)入本模塊所依賴的組件——AppComponent;
imports - 導(dǎo)入本模塊所需的其他模塊,這里的BrowserModule就是每個(gè)應(yīng)用的根模塊都要導(dǎo)入的,當(dāng)前它的名字叫AppModule;
bootstrap - 標(biāo)記出引導(dǎo)組件,也就是要渲染的那個(gè)。

platformBrowserDynamic().bootstrapModule(AppModule);最后一步,編譯啟動(dòng)!

OK, 最后我們還需要配置一下package.json,找到scripts這一項(xiàng):

"scripts": {
    "dev": "webpack-dev-server --inline --colors --progress --port 3000"
},

現(xiàn)在在終端輸入命令:npm run dev

在瀏覽器打開本地3000端口,即可看到結(jié)果,不知道你有沒有跑起來,反正我是跑起來了!(^__^)

額外的一些提醒 終端上的警告

回頭看終端,會(huì)報(bào)出兩個(gè)警告:

WARNING in ./~/@angular/core/src/linker/system_js_ng_module_factory_loader.js
71:15-36 Critical dependency: the request of a dependency is an expression

WARNING in ./~/@angular/core/src/linker/system_js_ng_module_factory_loader.js
87:15-102 Critical dependency: the request of a dependency is an expression

如果你心大,可以忽略它,如果想解決這兩個(gè)警告,可以配置一下webpack自帶的webpack.ContextReplacementPlugin插件!具體怎么做很容易谷歌到,我就不演示了。

另外還有個(gè)很簡(jiǎn)單的方法,在webpack.config.js里面的module里加一句exprContextCritical: false,就會(huì)忽略所有的警告了。

沒有用到的RxJS

我們?cè)倏纯?b>package.json,噢,好像有個(gè)叫rxjs的依賴包我們并沒有用到哦,那是不是跑Hello World不需要它呢?

No, 你如果刪掉它,會(huì)報(bào)錯(cuò)的哦!愿意折騰的同學(xué)盡管試試!

在網(wǎng)上看其他Angular 2 的教程,可能會(huì)看見配置項(xiàng)中有typings這樣的東西,是的,它跟Typescript相關(guān),但是在Typescript2.0之后已經(jīng)不需要這個(gè)東西了。

關(guān)于寫法

這次是為了簡(jiǎn)單,所以將組件和模塊以及渲染寫在同一個(gè)文件里,但幾乎所有的Angular教程都不會(huì)這么做,因?yàn)檫@不是最佳實(shí)踐,在實(shí)際的開發(fā)中,組件、模塊和引導(dǎo)都是分開的。

關(guān)于體積

我們看一下終端的輸出,哇塞,打包之后的JS文件才3M而已哦!

沒辦法,誰讓人家組件多呢?本來體積就不小。

首先這是開發(fā)環(huán)境,打包出來大是正常的,如果你在package.json里添加一個(gè)命令:

"scripts": {
    "dev": "webpack-dev-server --inline --colors --progress --port 3000",
    "build": "webpack -p"
},

在終端執(zhí)行npm run build

是不是就小了很多?這才是放進(jìn)瀏覽器的代碼,不過這也是挺大的,如果你不用gzip壓縮,我真的不知道是否有別的辦法進(jìn)一步壓縮它了。

希望通過這篇文章,能把你從一頭霧水的狀態(tài),提升為略懂吧!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92365.html

相關(guān)文章

  • Day 2: AngularJS —— 對(duì)AngularJS的初步認(rèn)識(shí)

    摘要:開始使用現(xiàn)在創(chuàng)建一個(gè)名為的文件,它將會(huì)是一個(gè)基于的網(wǎng)上書店應(yīng)用。這將初始化應(yīng)用程序,并告訴要在這一部分活躍。將為每個(gè)元素增加元素。控制器和視圖之間的粘合劑,而且會(huì)注入到。現(xiàn)在我們添加書籍?dāng)?shù)組的對(duì)象到對(duì)象,這個(gè)對(duì)象對(duì)視圖是可見的。 編者注:我們發(fā)現(xiàn)了比較有趣的系列文章《30天學(xué)習(xí)30種新技術(shù)》,準(zhǔn)備翻譯,一天一篇更新,年終禮包。以下是第二天技術(shù)的譯文。 昨晚我完爆了一天一技術(shù)的任務(wù)...

    joyqi 評(píng)論0 收藏0
  • angluar4使用非npm安裝的js插件和cnpm下使用bootstrap遇到的問題

    摘要:在引入將下載下來原諒沒看可以使用安裝,將那些,放入這個(gè)目錄里面。你要用聲明這個(gè)關(guān)鍵字這樣就可以在中使用了年月日指定元素使用出現(xiàn)沒有作用的之前用創(chuàng)建工程直接安裝和,然后安裝他的類型描述文件。 ??由于項(xiàng)目需要一個(gè)選擇年月日,選擇時(shí)分秒和選擇時(shí)見間隔的插件,本來打算用ng-zorro,結(jié)果發(fā)現(xiàn)ng-zorro有點(diǎn)不符合要求,而且有點(diǎn)大,所以就用了layDate.js。 在angular4引...

    lylwyy2016 評(píng)論0 收藏0
  • angluar4使用非npm安裝的js插件和cnpm下使用bootstrap遇到的問題

    摘要:在引入將下載下來原諒沒看可以使用安裝,將那些,放入這個(gè)目錄里面。你要用聲明這個(gè)關(guān)鍵字這樣就可以在中使用了年月日指定元素使用出現(xiàn)沒有作用的之前用創(chuàng)建工程直接安裝和,然后安裝他的類型描述文件。 ??由于項(xiàng)目需要一個(gè)選擇年月日,選擇時(shí)分秒和選擇時(shí)見間隔的插件,本來打算用ng-zorro,結(jié)果發(fā)現(xiàn)ng-zorro有點(diǎn)不符合要求,而且有點(diǎn)大,所以就用了layDate.js。 在angular4引...

    zhichangterry 評(píng)論0 收藏0
  • angluar4使用非npm安裝的js插件和cnpm下使用bootstrap遇到的問題

    摘要:在引入將下載下來原諒沒看可以使用安裝,將那些,放入這個(gè)目錄里面。你要用聲明這個(gè)關(guān)鍵字這樣就可以在中使用了年月日指定元素使用出現(xiàn)沒有作用的之前用創(chuàng)建工程直接安裝和,然后安裝他的類型描述文件。 ??由于項(xiàng)目需要一個(gè)選擇年月日,選擇時(shí)分秒和選擇時(shí)見間隔的插件,本來打算用ng-zorro,結(jié)果發(fā)現(xiàn)ng-zorro有點(diǎn)不符合要求,而且有點(diǎn)大,所以就用了layDate.js。 在angular4引...

    cjie 評(píng)論0 收藏0
  • Angular 2.x 0到1 (一)史上最簡(jiǎn)單的Angular2教程

    摘要:官方支持微軟出品,是的超集,是的強(qiáng)類型版本作為首選編程語言,使得開發(fā)腳本語言的一些問題可以更早更方便的找到。第一個(gè)組件那么我們來為我們的增加一個(gè)吧,在命令行窗口輸入。引導(dǎo)過程通過在中引導(dǎo)來啟動(dòng)應(yīng)用。它們的核心就是。 第一節(jié):Angular 2.0 從0到1 (一)第二節(jié):Angular 2.0 從0到1 (二)第三節(jié):Angular 2.0 從0到1 (三) 第一章:認(rèn)識(shí)Angular...

    tuniutech 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<