摘要:首先,要確認(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è)頁面看效果是不是?
編寫Hello WorldAngular 2 加載中……
我們先創(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,或者說叫
@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
摘要:開始使用現(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ù)...
摘要:在引入將下載下來原諒沒看可以使用安裝,將那些,放入這個(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引...
摘要:在引入將下載下來原諒沒看可以使用安裝,將那些,放入這個(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引...
摘要:在引入將下載下來原諒沒看可以使用安裝,將那些,放入這個(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引...
摘要:官方支持微軟出品,是的超集,是的強(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...
閱讀 1627·2021-11-22 14:45
閱讀 1085·2021-11-17 09:33
閱讀 3331·2021-09-02 09:48
閱讀 978·2019-08-30 15:54
閱讀 2775·2019-08-30 15:53
閱讀 2564·2019-08-30 12:54
閱讀 2251·2019-08-29 12:37
閱讀 2430·2019-08-26 13:58