文、意如
了解基本架構後就要來實際建立一個Angular專案了。
▶ 延伸閱讀:[Angular]1.初探篇
任務一:建立專案
1-1.建立開發所需要的檔案
1-2.建立dist資料夾來放置編譯後的網頁
任務二:程式流程運作
任務三:Component元件的屬性-資料顯示
3-1. 建立、插入值
3-2. 建立、插入陣列值
3-3. 建立、插入物件值
任務一:建立專案
1-1. 建立開發所需要的檔案
可以透過指令 ▶ ng generate component <name> 來快速建立開發所需要的檔案。
例如要建立mydatapage的一個元件(Component)。
指令為 ▶ ng generate component mydatapage
data:image/s3,"s3://crabby-images/6004b/6004b02a25b42fc7168870ac77049789635ed227" alt="angular01"
此時會在src/app中新增(CREATE)四個檔案,及更新(UPDATE) app.module.ts
mydatapage.component.css ▶ CSS樣式
mydatapage.component.html ▶ 基本模板Template
mydatapage.component.spec.ts ▶ 執行ng test命令會透過Karma進行測試
mydatapage.component.ts ▶ 元件Component
data:image/s3,"s3://crabby-images/aa7a4/aa7a49bbd115d26f0c5b3e5167cc324604ff8cad" alt="angular02"
1-2.建立dist資料夾來放置編譯後的網頁
使用ng build會在專案夾目錄下建立dist資料夾,專門放置已編譯後的網頁。
如要將此專案佈署至正式環境時,指令則是使用 ng build -prod 。
data:image/s3,"s3://crabby-images/17f42/17f42b0812855181d26208d5f00d5e4404c993a8" alt="angular03"
建立好之後,目錄上會多出dist資料夾,參考如下圖:
data:image/s3,"s3://crabby-images/58858/58858eada7c91a5777d591e3e418570ca1ea4440" alt="angular04"
任務二:程式運作流程
Angular 是一個SAP(Single Page Application)的網頁架構,
整個網站只有唯一的一張頁面index.html,所有的頁面切換、使用者介面等內容改變都是靠著JavaScript來做即時動態切換。
在index.html內會包含main.ts (JavaScript的執行檔)
起始頁請參考設定檔angular.json。
data:image/s3,"s3://crabby-images/d89d4/d89d482b744c9d456b0052111d3b1a0659c25d69" alt="angular05"
▶ 運作流程:1.index.html
在先前 ng build 所產生的index.html可以看到網頁載入了main.xxxxxxx.js
data:image/s3,"s3://crabby-images/34547/3454721199d44847ecbe41e0353bff831d2b824c" alt="angular06"
▶ 運作流程:1.index.html ▶ 2.main.ts
開啟main.ts ▶ 預設起始載入模組為app.module.ts(src/app/app.module)
bootstrapModule則使用app.module中的AppModule類別
data:image/s3,"s3://crabby-images/59a7b/59a7b0c10b0c92dd3a2ecbd2efd82a7c7a9cff25" alt="angular07"
▶ 運作流程:1.index.html ▶ 2.main.ts ▶ 3.app.module.ts
Angular主要透過元件(Component)來處理所有的介面,而元件必須在模組中設定。
先開啟src/app/app.module.ts
在 @NgModule 模組內中預設 bootstrap 屬性為 AppComponent 為起始元件。
因此引入app.component.ts(src/app/app.component.ts)
data:image/s3,"s3://crabby-images/63cfa/63cfa54f4a36d834cba8887b7ed2fa4103a91724" alt="angular08"
▶ 運作流程:1.index.html ▶ 2.main.ts ▶ 3.app.module.ts ▶ app.component.ts
1. 開啟src/app/app.component.ts
2. 因有宣告為 @Component ,因此AppComponent類別將視為angular中的一個元件(Component)
3. 元件中的selector 為css的選擇器,會將網頁包含app-root標籤替換成./app.component.html
4. 元件中的templateUrl 會將此樣板輸出至介面上
5. 元件中的styleUrls樣板會套用此樣式[可以同時指定多個樣式]
data:image/s3,"s3://crabby-images/f0ea7/f0ea72836ac513a0a2d81036259bb99b242cdbeb" alt="angular09"
了解了整個流程後,先開啟src/index.html 檔,可以看到有一個 <app-root></app-root>標籤,只要當Angular 在運作時就會被替換成app.component.html
data:image/s3,"s3://crabby-images/d3a03/d3a038034c6fda83fd143178ce6b831dd60ae9d9" alt="angular10"
接著開啟src/app/app.component.html
將原本的首頁內容全部刪掉,換成自己的內容
<h1>Welcome!!{{title}}</h1>
<h3>HelloWorld</h3>
data:image/s3,"s3://crabby-images/f527b/f527b8f747636d977a85ecb19aed10f2341c5299" alt="angular11"
最後透過指令ng serve --open
來啟動專案。
data:image/s3,"s3://crabby-images/90ff2/90ff2b7e6f7e707e5f7416c862faf77ab42e5e7c" alt="angular12"
此時會自動開啟瀏覽器,預設網址為:http://localhost:4200/
data:image/s3,"s3://crabby-images/c14ae/c14aeea2e13dd7ff0ebd3b9d0f890b0ef241d5a0" alt="angular13"
任務三:Component元件的屬性-資料顯示
3-1. 建立、插入值
路徑:src/app/app.component.ts
在AppComponet 元件中建立屬性變數為myparam = 'Yiru@Studio';
data:image/s3,"s3://crabby-images/94d4c/94d4cd3adcd43c065a32984202e00f62019c7995" alt="angular14"
路徑:src/app/app.component.html
使用兩個大括弧{{}} 來插入值,例如{{title}}、{{myparam}}
data:image/s3,"s3://crabby-images/048fe/048fea7d0284d5bb9412e072969ced1c4a28f04c" alt="angular15"
結果顯示:
data:image/s3,"s3://crabby-images/105ef/105ef212f4586ae4f92ee656cfd6066d849f4ee2" alt="angular16"
3-2. 建立、插入陣列值
路徑:src/app/app.component.ts
在AppComponet 元件中建立屬性陣列為:
member_name = ['John','Mary','Judy','Kevin'];
data:image/s3,"s3://crabby-images/ccb6a/ccb6a91092bf6ac18b82f4a7ef503bddd59b7372" alt="angular17"
路徑:src/app/app.component.html
使用*ngFor來讀取陣列並印出,
例:*ngFor = "let mbn of member_name"
mbn為自己宣告的變數名稱(key),of 後的member_name為要讀去的陣列屬性。
{{mbn}}會去讀取member_name陣列並印出。
data:image/s3,"s3://crabby-images/c7be2/c7be29a46b5e3fbdcd03d87a50d6a1d7fd27b666" alt="angular18"
結果如下:
data:image/s3,"s3://crabby-images/e1402/e14020751572e02ccfcc76f9a91aec0f31d57682" alt="angular19"
3-3. 建立、插入物件值
路徑:src/app/app.component.ts
在AppComponet 元件中建立屬性物件資料為:
weather = [
{day:'Monday',degrees:'16'},
{day:'Tuesday',degrees:'23'},
{day:'Wednesday',degrees:'19'},
{day:'Thursday',degrees:'25'},
{day:'Friday',degrees:'22'},
{day:'Saturday',degrees:'27'},
{day:'Sunday',degrees:'23'},
]
data:image/s3,"s3://crabby-images/0ebe0/0ebe099e7fdb29a3b3d9b03908510e229ab497a6" alt="angular20"
路徑:src/app/app.component.html
使用*ngFor來讀取物件並在表格中印出,
例:*ngFor = "let wr of weather"
wr為自己宣告的變數名稱(key),of 後的weather為要讀去的物件屬性。
{{wr.屬性}}會去讀取weather物件中的陣列資料並印出。
data:image/s3,"s3://crabby-images/b02f2/b02f24d3de36d121713dd447d2297e378b71c358" alt="angular21"
結果如下:
data:image/s3,"s3://crabby-images/59671/59671230c3cad3bd7866a6b3883f26127cecd4d9" alt="angular22"
Yiru@Studio - 關於我 - 意如