前端工程師必學知識!建立第一個Angular專案
data:image/s3,"s3://crabby-images/bfdee/bfdeebe6bf3acbc54a222e9ee1f0facd270f07db" alt=""
文、意如老師
建立第一個Angular專案,了解基本架構後就要來實際建立一個Angular專案了。
▶ 延伸閱讀:前端網頁工程師入門必備!認識Angular
任務一:建立專案
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/cf053/cf0535ec8155b92cd2ef90b603daf96c630c2165" alt=""
此時會在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/2c373/2c373d9d4e0323c2bdbb39f033c9f430d73c86d1" alt=""
1-2.建立dist資料夾來放置編譯後的網頁
使用ng build會在專案夾目錄下建立dist資料夾,專門放置已編譯後的網頁。
如要將此專案佈署至正式環境時,指令則是使用 ng build -prod 。
data:image/s3,"s3://crabby-images/202b8/202b8f02a730b3d15a1e10962a09f7f9ebfa7a7c" alt=""
建立好之後,目錄上會多出dist資料夾,參考如下圖:
data:image/s3,"s3://crabby-images/aabac/aabac74649a75e86b6aecd5fa22660b32bd07688" alt=""
任務二:程式運作流程
Angular 是一個SAP(Single Page Application)的網頁架構,整個網站只有唯一的一張頁面index.html,所有的頁面切換、使用者介面等內容改變都是靠著JavaScript來做即時動態切換。
在index.html內會包含main.ts (JavaScript的執行檔)
起始頁請參考設定檔angular.json。
data:image/s3,"s3://crabby-images/b6b62/b6b62b0ddf7ada568a241db819ae24a08d052611" alt=""
▶ 運作流程:1.index.html
在先前 ng build 所產生的index.html可以看到網頁載入了main.xxxxxxx.js
data:image/s3,"s3://crabby-images/224e7/224e706dd69432314861326495f4c8d8dd80c962" alt=""
▶ 運作流程: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/fc3c5/fc3c584e0ad249dab58a09c15b10488985b8c7ee" alt=""
▶ 運作流程: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/61440/6144017ddcaa9a228d274d557284d3d4b16f83d9" alt=""
▶ 運作流程: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/c9bae/c9baef9833a92c49fa8172b61ecfb36bc8fcaf4e" alt=""
了解了整個流程後,先開啟src/index.html 檔,可以看到有一個 <app-root></app-root>標籤,只要當Angular 在運作時就會被替換成app.component.html
data:image/s3,"s3://crabby-images/f466c/f466c8652ed8aa0dd1214cc46eba3aa66efb73ae" alt=""
接著開啟src/app/app.component.html
將原本的首頁內容全部刪掉,換成自己的內容
<h1>Welcome!!{{title}}</h1>
<h3>HelloWorld</h3>
data:image/s3,"s3://crabby-images/7b1b4/7b1b4dd7343cd4febf8eb8ba61ac6e4b16cf4ce0" alt=""
最後透過指令ng serve --open來啟動專案。
data:image/s3,"s3://crabby-images/6ecea/6eceaa12747f0be221b18c5969c4a7b3b36972c4" alt=""
此時會自動開啟瀏覽器,預設網址為:http://localhost:4200/
data:image/s3,"s3://crabby-images/b9166/b91664d0b94751afa62fae91c133f9d74c2466be" alt=""
任務三:Component元件的屬性-資料顯示
3-1. 建立、插入值
路徑:src/app/app.component.ts
在AppComponet 元件中建立屬性變數為myparam = 'Yiru@Studio';
data:image/s3,"s3://crabby-images/5042c/5042cbe92bb45603d1c16a10e776824fe4484589" alt=""
路徑:src/app/app.component.html
使用兩個大括弧{{}} 來插入值,例如{{title}}、{{myparam}}
data:image/s3,"s3://crabby-images/ec7b5/ec7b5da9d0fbd012e48eab8c3d630529921f30aa" alt=""
結果顯示:
data:image/s3,"s3://crabby-images/b84ef/b84ef4cfbfe04a832eb5a01daafb16aa94cb8a1b" alt=""
3-2. 建立、插入陣列值
路徑:src/app/app.component.ts
在AppComponet 元件中建立屬性陣列為:
member_name = ['John','Mary','Judy','Kevin'];
data:image/s3,"s3://crabby-images/87297/8729743498fb7a1b29ae01c3d71831f145b9527f" alt=""
路徑: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/56726/567265a77f767dd4237bdab70ea380b9bc3a99fa" alt=""
結果如下:
data:image/s3,"s3://crabby-images/67ea7/67ea7bf614f6c4826f5a987f831189f9d0c3b15e" alt=""
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/7c92c/7c92c0facc130633a5c156b17993bae0ec9a52c7" alt=""
路徑:src/app/app.component.html
使用*ngFor來讀取物件並在表格中印出,
例:*ngFor = "let wr of weather"
wr為自己宣告的變數名稱(key),of 後的weather為要讀去的物件屬性。
{{wr.屬性}}會去讀取weather物件中的陣列資料並印出。
data:image/s3,"s3://crabby-images/a0534/a0534f351ec6fb2926e4a76c74642ef6cf7ad03c" alt=""
結果如下:
data:image/s3,"s3://crabby-images/b560e/b560ee7008f056d9debf7c2964e1ecc054e3b974" alt=""
本文首圖圖片來源:Pexels
加入菜鳥救星官方Line並回覆「我想看文章」,不定期獲得更多知識吧!
不同頻道,不同知識!
Facebook Instagram Youtube