工程師帶你認識Angular中的路由與元件
data:image/s3,"s3://crabby-images/112c7/112c7d4085ebcfccd4a980254877a357f03f8927" alt=""
文、意如老師
上一篇介紹了 前端工程師必學知識!建立第一個Angular專案,這篇要帶大家認識Angular中的路由(Routing)與元件(Component),就讓我們繼續看下去吧!
任務一:認識Angular中的路由(Routing)
1.1. 認識路由
1.2. 認識路由插座<router-outlet></router-outlet>
1.3. 測試路由是否運作成功
任務二:實作應用
2.1.建立三個元件(Component)
2.2.建立路由規則
任務一:認識Angular中的路由(Routing)
1.1. 認識路由
一開始在專案建立時可以直接先新增路由。
data:image/s3,"s3://crabby-images/56de6/56de6a3c34f671f98b2ce0d5ab391346dcf74362" alt=""
接下來在app 路徑下會自動新增一個src/app/app-routing.module.ts
data:image/s3,"s3://crabby-images/eca47/eca4733afb5a52da559bec9462bfbfcbfdcef170" alt=""
1. 在routes變數加入路由規則:const routes: Routes = [];
2. 將routes路由變數宣告為根路由:[RouterModule.forRoot(routes)]
data:image/s3,"s3://crabby-images/71c22/71c22d7cc10a8af1f1d2f28efdca68529041b10b" alt=""
接著開啟路徑:src/app/app-routing.module.ts
1. 當Component註冊到模組時需要加在NgModule的declarations
2. 當NgModule要註冊到另一個NgModule時,則須加到imports屬性內
data:image/s3,"s3://crabby-images/c4654/c4654198a2cb7a5b69124e60ea995b23ebb8f228" alt=""
1.2. 認識路由插座
可以把路由插座<router-outlet></router-outlet>當作是Component(元件)中的標籤,當Angular運作路由時會找到這個<router-outlet></router-outlet>去指定Component。
運作流程:
1.index.html ▶
2.main.ts ▶
3.app.module.ts ▶
4.app.component.ts ▶ <router-outlet></router-outlet>
1.3. 測試路由是否運作成功
路徑:src/app/app.component.html
1. 刪除先前的程式碼,只需要打上路由插座標籤:<router-outlet></router-outlet>
data:image/s3,"s3://crabby-images/f4a57/f4a57fce920d3166cbfc918e05c648a5cacb0cfd" alt=""
2. 執行ng serve --open
data:image/s3,"s3://crabby-images/fd774/fd774b0a46c4b5951af49f9674ec295fed8dbcb6" alt=""
3. 出現空白頁面即代表路由是通的。
data:image/s3,"s3://crabby-images/89522/895227d2493db540d078d95c5ce5589dc9b86dea" alt=""
任務二:實作應用
2.1. 用三種方式建立三個元件(Component)
第一種方式:
使用輸入指令建立元件,指令為ng generate component [name],
另外也可以使用縮寫,指令為ng g c [name]
接下來建立一個mypage1的元件,指令為ng g c mypage1
data:image/s3,"s3://crabby-images/27433/274331145bef4e6103e87b2bc8c1bfe7d6e78382" alt=""
ng g c mypage1會自動建立一個與元件同名(mypage1)的資料夾,並在資料夾內產生4個檔案,最後再更新 AppModule(src/app/app.module.ts)。
data:image/s3,"s3://crabby-images/abac7/abac74a768dad07bd9adda8bf9115f822674e5a9" alt=""
1. 頁面設定:寫程式區
路徑:src/app/mypage1/mypage1.component.ts
此檔為主要程式撰寫的地方,這裡已自動宣告@Component 裝飾器的類別(Mypage1Component)。
data:image/s3,"s3://crabby-images/4d0a9/4d0a913de103179110e6eb451c3c83e479b12f46" alt=""
2. 頁面:對應的樣板
路徑:src/app/mypage1/mypage1.component.html
此檔為html撰寫的地方
data:image/s3,"s3://crabby-images/afb08/afb0890bc3fbc5db242b773bd97038a16ecd621f" alt=""
3. 頁面:樣板對應的樣式(CSS)
路徑:src/app/mypage1/mypage1.component.css
樣板所對應的樣式,預設為空白。
data:image/s3,"s3://crabby-images/2ce65/2ce65955d604d5b4cb3e3f86adf842b155ae0a08" alt=""
4. 頁面:單元測試
路徑:src/app/mypage1/mypage1.component.spec.ts
單元測試相關的程式碼,可以寫在此區。
data:image/s3,"s3://crabby-images/5d1ff/5d1ff770a8f5a431d582c04d775a3ec664401421" alt=""
5. 頁面:註冊到 AppModule
元件(Component)無法單獨存在,因此必須要註冊到NgModule的 declarations 屬性中。
路徑:src/app/app.module.ts
可以發現已經自動將Mypage1Component引入並註冊至app.module.ts中。
data:image/s3,"s3://crabby-images/28e5d/28e5dc7048daae4c96b1f6070bc5bf49688ae3df" alt=""
第二種方式:客製化建立mypage2的元件
如果方式一中自動建立的資料夾都不需要,可以在建立專案時加上 --flat 參數。
若不需要建立 style 樣式css檔,可以加上 -is 參數。
若不需要建立 template樣板檔html,可以加上 -it 參數。
若不需要建立 unit testing 單元測試檔spec.ts,可以在 angular.json內的 schematics加上此段程式碼
"@schematics/angular:component": {
"skipTests": true
}
data:image/s3,"s3://crabby-images/bdc68/bdc68bda7232fc195a74afa925b82b34328daf95" alt=""
接著馬上來建立一個mypage2的元件,指令為ng g c mypage2 --flat -is -it
data:image/s3,"s3://crabby-images/021f9/021f9314e728f34d8cecc627011930ec657c186f" alt=""
此時只會自動建立src/app/mypage2.component.ts檔案
及更新 AppModule(src/app/app.module.ts)。
data:image/s3,"s3://crabby-images/42fec/42fec4ff62c7cb6b1d9b13f48a7ab47704606e32" alt=""
方式一與方式二的差別
主要是 @Component 內 templateUrl 被取代成 template ,styleUrls 被取代成 styles ,如果是只是少量的內容就可以使用此方法寫在 template 屬性中、把樣式內容填寫在 styles 屬性。
data:image/s3,"s3://crabby-images/d9087/d9087cb1ff25529c87b4446ca2c819133106292c" alt=""
第三種方式:純手動建立mypage3的元件
步驟一:直接點選app資料夾新增檔案,命名為:mypage3.component.ts
data:image/s3,"s3://crabby-images/75797/757976e5ef0172b141857bbc88ad8ecdda321d25" alt=""
路徑:src/app/mypage3.component.ts
目前是一個沒有內容的空檔案
data:image/s3,"s3://crabby-images/465ea/465eaacbbf91764f3d6a9820bcd327c3c4260e36" alt=""
步驟二:mypage3.component.ts中輸入a-,選擇a-component 。
data:image/s3,"s3://crabby-images/262f2/262f2e503ace09e1521cc4b5135a80f663a6995f" alt=""
則會自動產生基本程式架構。
data:image/s3,"s3://crabby-images/bc8d9/bc8d95c4e591305c1980b487b2e00f4835940c96" alt=""
步驟三:手動修改部分程式碼
data:image/s3,"s3://crabby-images/e5495/e54954273b5341277176730a3bd5079e1fe42930" alt=""
最後步驟:
開啟路徑 src/app/app.module.ts
將 mypage3Component元件註冊到AppModule模組上即可完成。
data:image/s3,"s3://crabby-images/21b80/21b8053b86c15b2684dce218745c219bbf4f2737" alt=""
重啟專案並套用這三個元件
開啟路徑 src/app/app.component.html ,
1. 加入這三個元件:
<app-mypage1></app-mypage1>
<app-mypage2></app-mypage2>
<app-mypage3></app-mypage3>
2. 執行指令 ng serve
data:image/s3,"s3://crabby-images/73e40/73e408871f43dfc1c082bed4e816e4e628bd012c" alt=""
3. 透過瀏覽器輸入:http://localhost:4200/ 看顯示結果。
data:image/s3,"s3://crabby-images/11ac8/11ac82d7c7d1b9db7c9bd9a3d4b3733e16520607" alt=""
2.2. 建立路由規則
如要將這三個元件,變成三張網頁,可以建立路由規則。
開啟路徑:src/app/app-routing.module.ts,接著在此檔案中加入3個路由規則,分別對應到 Mypage1Component、Mypage 2Component、Mypage 3Component。
path:設定導覽的相對路徑
component:設定要載入的 Component
data:image/s3,"s3://crabby-images/3e7f6/3e7f6565827f88e9d6e168e31c8dbff891d622f7" alt=""
最後記得在此路徑加上路由插座
src/app/app.component.html
<router-outlet></router-outlet>
啟動專案指令為:ng serve --open
data:image/s3,"s3://crabby-images/3c545/3c545fc8606ce7c1314a955fbb1635a2659b34ef" alt=""
最後打開瀏覽器,分別輸入
http://localhost:4200/p1,
http://localhost:4200/p2,
http://localhost:4200/p3
顯示結果如下圖:
data:image/s3,"s3://crabby-images/d51ef/d51efcd5ecde35821385ac927e09a7ce053b997b" alt=""
本文首圖圖片來源:Pexels
以下是為了能夠滿足段落所需的長度而定義的無意義內文,請自行參酌編排。
以下是為了能夠滿足段落所需的長度而定義的無意義內文,請自行參酌編排。
Facebook Twitter Youtube