Node.js + MongoDB建立最愛球員清單

閱讀時間約 3 分鐘

※ 專案起源

建立一個屬於自己喜愛球員的清單。

※ 成果發表


raw-image
raw-image
raw-image


※ 專案開發環境

  1. 架設 Node.js 伺服器。

原因:為了讓我所使用的程式語言JavaScript ,擁有能夠開發網路應用程式的能力,所以我用Node.js 來架設伺服器。

優點:

  • 有了 Node.js,JavaScript 可以直接建立、讀取、修改和刪除電腦內的檔案,並且能和資料庫連通。
  • Node.js具有網路應用程式需要的功能,例如作為伺服器處理用戶端發出請(request) 並給予回應 (response) 等。
  1. 用 Express.js 進行全端開發。

原因:Express 提供了一個強大的路由系統、豐富的內建中間件、使用模板引擎來動態生成 HTML等優點,讓程式碼更簡潔,開發速度更快速。

優點: 有了「網路框架」 (web framework) 讓我能夠分割負責不同功能的程式碼,以增加每一份檔案的易讀性,也讓程式碼更容易被維護。

  1. 用 MongoDB 資料庫。

原因:

  • 現階段使用者最多、生態系也最完整的文件資料庫。
  • 用 Express.js 開發應用程式時,會希望能直接用 JavaScript 操作資料庫,而不需要另外撰寫 SQL。

※ 專案開發技術

  • 使用 Express handlebars,為球員清單做出佈局和局部樣板的畫面。
  •  套入 Bootstrap在球員清單 的 HTML。
  • 將Handlebars 的語法跟原有的 HTML 語法與格式配合,顯示動態資料:圖片連結 - player.image 是放在 src = "{{this.images.index}} " 裡面
  • 在 handlebars 樣板中使用 each 迴圈,呈現多筆球員資料。
  • 讀取 JSON 檔案 ,將外部資料帶入樣板引擎中,讓網頁呈現出 50位球員資料。
  • 使用 :params 來取得網址資訊的路由,建立動態路由讓使用者可以在瀏覽器畫面上看到自己在網址列所輸入的內容。
  • 透過 req.query 取得網址 ? 後方的查詢字串(queryString)
  • 運用CRUD 功能,呈現瀏覽所有或特定球員資料,新增、修改和刪除球員資料。
  • 依照RESTful 風格優化路由設計。
  • 設定 express-session,來判斷使用者的登入狀態。
  • 設定 Passport.js,完成登入功能。
  • 運用middleware驗證登入狀態。
  • 使用 connect-flash 來建立快閃訊息 (flash message),作為提示使用者。
  • 使用 bcrypt 處理密碼,讓使用者在登入和註冊時輸入的密碼。
  • 整合 Facebook 第三方登入。
  • Promise.all 語法結構重構種子資料 。

※ 專案功能

使用者可以在首頁看到所有球員的簡單資料:

1. 球員照片

2. 球員名稱

3. 球員背號

使用者可以再點進去看球員的詳細資訊:

1. 英文名字

2. 職位名稱

3. 身高

4. 體重

5. 學歷

6. 出生年月日

使用者可以透過搜尋球員名稱來找到特定的球員

使用者可以透過搜尋職位名稱來找到特定的球員

使用者可以新增一位球員

使用者可以瀏覽一位球員的詳細資訊

使用者可以瀏覽全部所有球員

使用者可以修改一位球員的資訊

使用者可以刪除一位球員

使用者可以註冊

使用者可以登入

使用者可以透過Facebook Login 直接登入

全端網頁開發專業知識分享
留言0
查看全部
發表第一個留言支持創作者!
Java Script自學經驗回顧
閱讀時間約 1 分鐘
認識程式與電腦
閱讀時間約 1 分鐘
老爸的私房錢的專案介紹
閱讀時間約 2 分鐘
專案開發心得-Simple Twitter
閱讀時間約 4 分鐘
A28: 畢業部落格-自我成長
閱讀時間約 2 分鐘
你可能也想看
Node.js 學習筆記(六):使用 Express 框架如何安裝、初階使用 Express 框架的學習筆記。
Thumbnail
avatar
蕭宇廷
2023-11-24
Node.js 學習筆記(五):NPM 宇宙 🌏如何善用 NPM 安裝現成套件,提高開發效率
Thumbnail
avatar
蕭宇廷
2023-11-23
Node.js 學習筆記(四):模組初探 Node.js 的模組概念,以及 module 物件中的 exports 與 require 屬性,完成模組輸出與帶入。
Thumbnail
avatar
蕭宇廷
2023-11-22
Node.js 學習筆記(三):快速搭建一台網站伺服器參考 Node.js 官方文件,快速建立一個簡單的網站伺服器~
Thumbnail
avatar
蕭宇廷
2023-11-21
Node.js 學習筆記(二):用 JavaScript 操作電腦的檔案系統用 Node.js 實作電腦檔案系統操作,包含建立資料夾、新增檔案等等。
Thumbnail
avatar
蕭宇廷
2023-11-21
Node.js 學習筆記(一):為何使用與如何安裝簡單紀錄使用 Node.js 的好處,以及安裝 Node.js 的建議作法,最後也簡單提及了 Node.js 的 REPL 環境,讓我們能直接在 terminal 寫 JavaScript 程式。
Thumbnail
avatar
蕭宇廷
2023-11-20
Node.js 筆記 | 基本操作Node.js 基礎操作篇
Thumbnail
avatar
Jeremy Ho
2023-08-09
Node.js教學影音: https://youtu.be/SY5sRC2idk0 ============ 安裝 Node.js 步驟 1. http://nodejs.org/ 下載安裝 npm install connect npm install express npm install morgan
avatar
吳佳鑫
2022-05-21
從你的 Node.js 專案裡找出 Memory leak,及早發現、及早治療!前陣子公司的專案時常發生記憶體不足的錯誤,套上監測軟體一看,逐漸攀升的使用量,到達上限後使程式崩潰,同事們馬上說出:「這是 Memory leak 啊!」 Memory leak 並不可怕,現代的工具可以讓我們快速找出問題並修正,這篇文章記錄了我們的解決方式,希望有幫助到大家!
Thumbnail
avatar
Kuan
2021-08-14
Node.js 爬蟲 — 自動化下載 1,178 張吉卜力作品劇照最近對爬蟲感到興趣,幾天的研究發現 Puppeteer 這套由 Google 開源、使用無介面操作 Chrome 做自動化測試的 Node.js 函式庫也能用來爬取資料...
Thumbnail
avatar
Ray C
2021-02-24