--- tags: Node.js 直播班 - 2022 春季班 --- # 🏅 Day 12 ## 設計基本路由 延續前一天的每日任務,我們設定當造訪根目錄 `'/'`時,會回傳 Hello World,接著可以此類推,設定當造訪其他頁面的路由(router) Express 定義路由的結構如下 ```javascript app.METHOD(PATH, HANDLER) ``` - `app` 是 `express` 的實例。 - `METHOD` 是 [HTTP 要求方法](http://en.wikipedia.org/wiki/Hypertext_Transfer_Protocol)。 - `PATH` 是伺服器上的路徑。 - `HANDLER` 是當路由相符時要執行的函數。 以[最終作業設計稿](https://xd.adobe.com/view/c0763dbe-fc15-42e8-be0b-8956ed03e675-9525/grid)為例,當造訪「全體動態牆」頁面時,路由可以設定為 ```javascript app.get('/posts', (req, res) => { res.send('全體動態牆') }) ``` 新增貼文(POST 請求) ```javascript app.post('/posts', (req, res) => { res.send('新增一則貼文') }) ``` 若是使用者的個人頁面,因每個使用者會有各自的 id 或帳號,此時就可以設計成動態路由 再透過 `req.params` 取得參數 ```javascript app.get('/user/:id', (req, res) => { const id = req.params.id res.send(`${id} 個人頁面`) }) ``` ### 參考資源 [Express 基本路由](https://expressjs.com/zh-tw/starter/basic-routing.html) [網址規則介紹](https://courses.hexschool.com/courses/1670869/lectures/39299599) 到 [query - 取得網址參數](https://courses.hexschool.com/courses/1670869/lectures/39299606)(章節影片) ### 題目(將答案貼在 HackMD 並提交至回報區) 參考[最終作業設計稿](https://xd.adobe.com/view/c0763dbe-fc15-42e8-be0b-8956ed03e675-9525/grid)頁面,設計當使用者造訪以下頁面(`GET`)時的路由, response 可先回傳一段簡單的文字即可 - 登入 - 註冊 - 全體動態牆 - 個人牆 - 個人追蹤名單 範例 ```javascript app.get('/login', (req, res) => { res.send('歡迎來到登入頁') }) ``` 回報流程 --- 請同學依照下圖教學觀看解答、回報答案: ![](https://i.imgur.com/QtL8zEW.png) 回報格式:請在「回報區」貼上 CodePen 或 HackMD 連結回報答案 (為了統計人數,請同學依序加上「報數」) <!-- 解答 ```javascript - 登入 app.get('/login', (req, res) => { res.send('歡迎來到登入頁') }) - 註冊 app.get('/signin', (req, res) => { res.send('歡迎來到註冊頁') }) - 全體動態牆 app.get('/posts', (req, res) => { res.send('歡迎來到全體動態牆') }) - 個人牆 app.get(`/user/:id`, (req, res) => { const id = req.params.id res.send(`歡迎來到 ${id} 個人動態`) }) // path 設定為 `/:id` 也可以 - 個人追蹤名單 app.get(`/user/:id/following`, (req, res) => { const id = req.params.id res.send(`${id} 追蹤名單`) }) // path 設定為 `/:id/following` 也可以 ``` --> 回報區 --- | 報數 | 組別 / 名字 | codepen / hackMD / 其他回饋 | | ---- | -------------------- | -------------------------------------------------------------------------------------------------------------------- | | 1 | 第 6 組 / Wendy | [HackMD](https://hackmd.io/@0k_MSPdgRPujozP6w_D-bA/Hy0bV_mS9) | | 2 | 第 2 組 / Vic | [HackMD](https://hackmd.io/HSVP0rHETSi85KHiF4XZ3w) | | 3 | 第 2 組 / Jin | [HackMD](https://hackmd.io/0KXBPG5xQnC-1Cbami4_Lg) | | 4 | 第 3 組 / HedgehogKU | [HackMD](https://hackmd.io/rq3umQonRb2peE29nw-FJw) | | 5 | 第 4 組 / 小宥 | [HackMD](https://hackmd.io/q1ZgCKd-QaOJq5Gkp4vkHw) | | 6 | 第 3 組 / Hobby | [HackMD](https://hackmd.io/@hobbyling/day12) | | 7 | 第 4 組 / sihle | [HackMD](https://hackmd.io/@bugbug777/SktX1KmH5) | | 8 | 第 9 組 / 黃士桓 | [HackMD](https://hackmd.io/8hPKV4zlRSOj6rhdwZ0HPA) | | 9 | 第 2 組 / Genos | [HackMD](https://hackmd.io/5A8AcAMeSSOA96WvjFH48g) | | 10 | 第 14 組|East | [HackMD](https://hackmd.io/fs-W0SKaSKW1H1N6wFAQ7w) | | 11 | 第 5 組 / Hazel | [HackMD@Hazel](https://hackmd.io/@hazelwu/day12) | | 12 | Naiky | [HackMD@Naiky](https://hackmd.io/@UWBC7rrORiKaLSBg226mZg/B14dcc7Sq) | | 13 | 第 2 組 / peter | [HackMD](https://hackmd.io/@peterchen1024/BkWY4jQrc) | | 14 | 第 6 組 / Ruta | [HackMD](https://hackmd.io/ZXRBOBXVR6O0xvI7zvL2qQ) | | 15 | 第 3 組 / hiYifang | [HackMD](https://hackmd.io/@gPeowpvtQX2Om6AmD-s3xw/HkiSA6Jrc) | | 16 | 第 2 組 / joe chang | [HackMD](https://hackmd.io/uaRTw9c0TgOrADyXMmGL0Q?view#425---%E8%A8%AD%E8%A8%88%E5%9F%BA%E6%9C%AC%E8%B7%AF%E7%94%B1) | | 17 | 第 2 組 / Rikkubook | [HackMD](https://hackmd.io/27BI5WY2TUiotCtVGHDy8w) | | 18 | 第 4 組 / 苡安 | [HackMD](https://hackmd.io/oyTNvblxREGiLwtNH_xuYQ) | |19 |第 9 組 / konstante |[HackMD](https://hackmd.io/VuTPH4cHSd6DXEEEHBBMRw?both) |20 |第 2 組 / wendy.li |[HackMD](https://hackmd.io/z1WIdu59TuOmaaMKUj9fBw) | 21 | 第 12 組 / Jimmy | [HackMD](https://hackmd.io/uc7pq9dHSwuBhHLMokNTJw?view) |22 |第 10 組 / 橘子 |[HackMD](https://hackmd.io/pdx9tWc5ThyUlbhZ84Av0g) |23 |第 11 組 / Han Lai |[HackMD](https://hackmd.io/9xS2NcFNTR-ScMAZCg3jWw?view) |24 |第 8 組 / Hank |[HackMD](https://hackmd.io/@TFOivyvXT-qpG6SieUTfgw/S1xg7HNS9) |25 |第 1 組 / Claire |[HackMD](https://hackmd.io/Vy41ZUQfQN6bMUf7DhcyRQ) | 26 |第 15 組 / Chiu |[HackMD](https://hackmd.io/sIbNcIDNRhm5MQxzyNkBmw?view) | 27 | 第 3 組 / Larry | [HackMD](https://hackmd.io/Nexj_UDNTWuYVYZ8Mob3qA) | | 28 | 第 3 組 / Adam Hsu | [HackMD](https://hackmd.io/@S9gD__kVTSiQUupQNn_4FQ/BkXaWA4r9) | 29 | 第 16 組 / 皓皓 | [HackMD](https://hackmd.io/@cutecat8110/S1Ncl1HH9) | 30 | 第 8 組 / Jordan Tseng | [HackMD](https://hackmd.io/ZrTWxsf4RhGXqneNG-NbVQ) | 31 | 第 15 組 / Tofu | [HackMD](https://hackmd.io/NCYzANZKQuueo_KGn3O0XA) | 32 | 第 10 組 / Otis | [HackMD](https://hackmd.io/@wAXXVY7eQ2WkcVtv8Vopzg/Bkhr-tHrq) | 33 | 第 13 組 / KFC |[HackMD](https://hackmd.io/HMUm3Zf_SUqYFwcAuP1IDg)| | 34 | 第 3 組 / Justin |[HackMD](https://hackmd.io/Ud99s9xURH-6HgktAQpimQ)| | 35 | 第 1 組 / Ed Huang |[HackMD](https://hackmd.io/-EEiVV_rSXCmQguAlj-zzQ?view)| |36 |第 11 組 / Jamie Lee |[HackMD](https://hackmd.io/z0Tsi83zSlO38GkquyCINA?view) | 37 | 第 9 組 / Reynold | [HackMD](https://hackmd.io/@dL7AuQEMQ6KpCSRHaYElOA/BJuXrk_rc) | 38 | nick6303 | [HackMD](https://hackmd.io/slwzUvHvRDyooJ5f2BD2QQ)| | 39 | 第14組/uniza| [HackMD](https://hackmd.io/AXQyCLN2S_OeNgEPdV3mIQ)| | 40 | 第 1 組 / snow| [HackMD](https://hackmd.io/@snowsuika/rymhtsiH5)| | 41 | 第 7 組 / jason06286| [HackMD](https://hackmd.io/_xLqZC_oRzGLfABFywMYmw)| | 42 | 第 15 組 / yolala| [HackMD](https://hackmd.io/8hPKV4zlRSOj6rhdwZ0HPA)| | 46 | 第 5 組 / Nap | [HackMD](https://hackmd.io/@8x8YzkXNSzafUSO3LZTmUw/r1d37rCHq)| | 47 | 第 3 組 / 小葉 | [HackMD](https://hackmd.io/@FyKv37KcRSWqAO_e336w8g/HJCxTIRr9)| | 48 | 第11 組 / mandy | [HackMD](https://hackmd.io/0awuuYctT9elgdXmffpJ_g)| | 49 | 第 1 組 / Emily Hsi | [HackMD](https://hackmd.io/@EmilyHsi/rJTNUx-85)|