Vim使用教學

Vim 使用教學手冊 目錄 前言 Vim 在專案中的角色 為什麼要學習 Vim 本手冊的學習方式與使用建議 第一篇:Vim 基礎入門 1. Vim 簡介 2. 安裝與環境設定 3. Vim 的操作模式 4. 文字編輯基礎 5. 檔案操作 第二篇:進階編輯技巧 6. 搜尋與取代 7. 巨集與自動化 8. 多檔案編輯與快速導覽 9. 文本處理進階 第三篇:專案開發實務 10. Vim 與程式開發 11. 插件管理 12. Git 與版本控制整合 13. 日常開發案例 第四篇:考試與認證準備 14. Vim 認證簡介 15. 模擬練習題 16. 學習路線圖 附錄 Vim 常用快捷鍵速查表 常見錯誤排解 推薦書籍與網站 練習建議 檢查清單(Checklist) 新進成員 Vim 技能檢查清單 團隊協作檢查清單 系統管理檢查清單 持續改進檢查清單 前言 Vim 在專案中的角色 在現代軟體開發專案中,Vim 扮演著重要的角色: Linux 伺服器管理必備工具:在產品環境中進行設定檔編輯、日誌查看、緊急修復 高效率文字編輯器:相較於圖形界面編輯器,Vim 在純文字環境下具有絕對優勢 跨平台一致性:無論在 Linux、macOS 或 Windows 環境,Vim 都能提供相同的操作體驗 與開發工具整合:許多現代 IDE 都提供 Vim 模式,學會 Vim 能提升整體開發效率 為什麼要學習 Vim mindmap root((為什麼學 Vim)) 效率提升 快速編輯 鍵盤操作 減少滑鼠依賴 專業需求 Linux 系統管理 遠端作業 伺服器維護 認證考試 LPIC RHCE CompTIA Linux+ 技能發展 文字處理專精 自動化能力 工具整合 本手冊的學習方式與使用建議 循序漸進:建議按章節順序學習,每章都有實作練習 動手實作:理論與實務並重,務必完成每章的練習題 日常應用:將學會的技巧應用到實際專案開發中 認證導向:標註的認證重點可作為考試準備參考 第一篇:Vim 基礎入門 1. Vim 簡介 簡介 Vim(Vi IMproved)是基於經典的 Vi 編輯器所改良的文字編輯器,是 Unix/Linux 系統中最重要的編輯工具之一。 ...

October 31, 2025 · 35 min · 7268 words · Eric Cheng

Visual Studio Code使用教學

Visual Studio Code 使用教學手冊 完整的 VS Code 開發環境設定與實戰指南 涵蓋前端 (Vue 3 + TypeScript) 與後端 (Spring Boot) 開發,適用於團隊協作與企業級專案開發 📋 目錄 1. VS Code 安裝與環境設定 1.1 安裝步驟 1.2 推薦字型與主題 1.3 專案必要的 Extensions 清單 1.4 設定同步功能 1.5 設定檔 (Profiles) 管理 1.6 實務案例與注意事項 2. 專案開發環境配置 2.1 如何開啟專案 2.2 前端、後端工作區設定 2.3 編碼規範設定 2.3.1 前端編碼規範 (ESLint + Prettier) 2.3.2 後端編碼規範 (Checkstyle) 2.3.3 Maven 獨立安裝設定 2.4 容器化開發環境 (Dev Containers) 2.5 實務案例與注意事項 3. 日常開發操作 3.1 Git 與 GitHub/GitLab 整合 3.2 常用快捷鍵 3.3 偵錯與斷點設定 3.4 終端機與多工作區使用 3.5 程式碼片段 (Snippets) 使用 3.6 實務案例與注意事項 4. 專案特定開發流程指引 4.1 前端開發流程 4.2 後端開發流程 4.3 全端開發工作流程 4.4 程式碼品質檢查 4.5 Python 開發環境設定 4.5.1 Python 專案結構 4.5.2 Python 環境設定 4.5.3 Python 開發工具設定 4.5.4 Python 偵錯設定 4.5.5 Python 任務設定 4.5.6 Python 專案範例 4.5.7 Python 開發最佳實務 4.6 效能監控與分析 4.7 實務案例與注意事項 5. 協作開發功能 5.1 Live Share 即時協作 5.2 多人開發設定 5.3 程式碼審查工具 5.3.1 GitHub Pull Request 整合 5.3.2 GitLab Merge Request 整合 5.3.3 程式碼審查檢查清單 5.4 團隊協作最佳實務 6. 進階功能與擴充 6.1 自訂程式碼片段 6.2 擴充功能開發入門 6.2.1 建立基本擴充功能 6.2.2 擴充功能專案結構 6.2.3 擴充功能基本開發 6.2.4 發布擴充功能 6.3 工作流程自動化 6.3.1 Task 自動化 6.3.2 GitHub Actions 整合 6.3.3 GitLab CI/CD 整合 6.4 效能優化進階技巧 6.4.1 檔案監控與搜尋優化 6.4.2 編輯器效能設定 6.4.3 擴充功能效能管理 6.4.4 大型專案效能建議 6.5 遠端開發與 SSH 6.5.1 Remote Development 概述 6.5.2 Remote SSH 設定 6.5.3 Remote Tunnels(安全隧道) 6.5.4 GitHub Codespaces 6.5.5 遠端開發最佳實務 6.6 工作區管理進階技巧 7. AI 輔助開發與 GitHub Copilot 7.1 GitHub Copilot 基礎設定 7.1.1 安裝與啟用 7.1.2 行內建議 (Inline Suggestions) 7.1.3 聊天功能 (Chat) 7.1.4 Smart Actions(智慧動作) 7.1.5 審查與管理 AI 變更 7.2 Agent 模式與工作階段管理 7.2.1 Agent 類型 7.2.2 工作階段管理 7.2.3 子代理 (Subagents) 7.3 Plan Agent 規劃代理 7.4 自訂 AI 行為 7.4.1 自訂指令 (Custom Instructions) 7.4.2 Prompt Files(提示檔案) 7.4.3 自訂代理檔案 7.4.4 Agent Skills(正式版) 7.4.5 組織層級指令 7.4.6 Hooks(生命週期鉤子) 7.4.7 疑難排解 7.5 MCP 伺服器整合 7.6 Copilot Memory(預覽) 7.7 語言模型管理 7.7.1 選擇語言模型 7.7.2 Anthropic 模型整合(Claude) 7.7.3 語言模型編輯器 7.8 AI 開發常用快捷鍵 7.9 AI 開發最佳實務 7.9.1 有效使用 AI 的建議 7.9.2 Agent 使用場景指引 7.9.3 安全性考量 8. 最佳實務 8.1 常見問題 (FAQ) 與解決方式 8.2 建議的工作習慣 8.3 效能最佳化 8.4 安全性最佳實務 8.5 團隊協作規範 9. 檢查清單 9.1 新進成員快速上手檢查清單 9.2 日常開發檢查清單 9.3 部署前檢查清單 9.4 故障排除檢查清單 10. 附錄 10.1 參考資源 10.2 聯絡支援 10.3 版本歷程 1. VS Code 安裝與環境設定 1.1 安裝步驟 1.1.1 下載與安裝 前往 Visual Studio Code 官方網站 點擊 “Download for Windows” 下載安裝檔 執行安裝檔,建議勾選以下選項: ✅ 新增至 PATH (在重新啟動後可用) ✅ 在檔案總管中的檔案上顯示「使用 Code 開啟」動作 ✅ 在檔案總管中的目錄上顯示「使用 Code 開啟」動作 ✅ 將 Code 註冊為支援的檔案類型的編輯器 1.1.2 首次啟動設定 啟動 VS Code 選擇適合的色彩主題 登入 Microsoft 帳戶(可選,用於同步設定) 1.2 推薦字型與主題 1.2.1 推薦字型 建議安裝並使用以下等寬字型: ...

October 31, 2025 · 43 min · 9129 words · Eric Cheng

Visual Studio Code使用教學

Visual Studio Code 使用教學手冊 完整的 VS Code 開發環境設定與實戰指南 涵蓋前端 (Vue 3 + TypeScript) 與後端 (Spring Boot) 開發,適用於團隊協作與企業級專案開發 📋 目錄 1. VS Code 安裝與環境設定 1.1 安裝步驟 1.2 推薦字型與主題 1.3 專案必要的 Extensions 清單 1.3.1 基礎開發工具 1.3.2 前端開發 1.3.3 後端開發 1.3.4 Python 開發 1.3.5 AI 輔助開發 1.3.6 一鍵安裝指令 1.4 設定同步功能 1.5 實務案例與注意事項 2. 專案開發環境配置 2.1 如何開啟專案 2.2 前端、後端工作區設定 2.3 編碼規範設定 2.3.1 前端編碼規範 (ESLint + Prettier) 2.3.2 後端編碼規範 (Checkstyle) 2.3.3 Maven 獨立安裝設定 2.4 容器化開發環境 (Dev Containers) 2.5 實務案例與注意事項 3. 日常開發操作 3.1 Git 與 GitHub/GitLab 整合 3.2 常用快捷鍵 3.3 偵錯與斷點設定 3.4 終端機與多工作區使用 3.5 程式碼片段 (Snippets) 使用 3.6 AI 輔助開發 — GitHub Copilot 3.6.1 程式碼自動完成與 Next Edit Suggestions 3.6.2 Copilot Chat 對話式助手 3.6.3 Inline Chat(行內聊天) 3.6.4 智慧動作 3.6.5 Agent 模式與 Agent Sessions 3.6.6 Autopilot 與 Agent 權限控制 3.6.7 Plan Agent(計畫代理) 3.6.8 自訂指示檔 3.6.9 MCP 伺服器整合 3.6.10 Custom Agents(自訂代理) 3.6.11 Agent Skills(代理技能) 3.6.12 Prompt Files(提示檔案) 3.6.13 Hooks(生命週期鉤子) 3.6.14 語言模型選擇 3.7 實務案例與注意事項 4. 專案特定開發流程指引 4.1 前端開發流程 4.2 後端開發流程 4.3 全端開發工作流程 4.4 程式碼品質檢查 4.5 效能監控與分析 4.6 實務案例與注意事項 4.7 Python 開發環境設定 4.7.1 Python 專案結構 4.7.2 Python 環境設定 4.7.3 Python 開發工具設定 4.7.4 Python 偵錯設定 4.7.5 Python 任務設定 4.7.6 Python 專案範例 4.7.7 Python 開發最佳實務 5. 協作開發功能 5.1 Live Share 即時協作 5.2 多人開發設定 5.3 程式碼審查工具 5.3.1 GitHub Pull Request 整合 5.3.2 GitLab Merge Request 整合 5.3.3 程式碼審查檢查清單 5.4 團隊協作最佳實務 6. 進階功能與擴充 6.1 自訂程式碼片段 6.2 擴充功能開發入門 6.3 工作流程自動化 6.3.1 Task 自動化 6.3.2 GitHub Actions 整合 6.3.3 GitLab CI/CD 整合 6.4 效能優化進階技巧 6.5 遠端開發與 SSH 6.6 工作區管理進階技巧 6.7 設定檔 (Profiles) 管理 6.8 Chat Customizations 編輯器 7. 最佳實務 7.1 常見問題 (FAQ) 與解決方式 7.2 建議的工作習慣 7.3 效能最佳化 7.4 安全性最佳實務 7.5 團隊協作規範 8. 檢查清單 8.1 新進成員快速上手檢查清單 8.2 日常開發檢查清單 8.3 部署前檢查清單 8.4 故障排除檢查清單 9. 附錄 9.1 參考資源 9.2 版本歷程 1. VS Code 安裝與環境設定 1.1 安裝步驟 1.1.1 下載與安裝 前往 Visual Studio Code 官方網站 點擊 “Download for Windows” 下載安裝檔 執行安裝檔,建議勾選以下選項: ✅ 新增至 PATH (在重新啟動後可用) ✅ 在檔案總管中的檔案上顯示「使用 Code 開啟」動作 ✅ 在檔案總管中的目錄上顯示「使用 Code 開啟」動作 ✅ 將 Code 註冊為支援的檔案類型的編輯器 1.1.2 首次啟動設定 啟動 VS Code 選擇適合的色彩主題 登入 Microsoft 帳戶(可選,用於同步設定) 1.2 推薦字型與主題 1.2.1 推薦字型 建議安裝並使用以下等寬字型: ...

October 31, 2025 · 43 min · 9002 words · Eric Cheng

Vue3 前端framework教學

Vue 3.x 前端 Framework 教學手冊 📘 適用對象:完全沒有學過 Vue 3 的新進開發同仁 🎯 學習目標:循序漸進掌握 Vue 3.x 開發技能,並具備專案實戰能力 🏆 認證準備:涵蓋 Vue 3 官方認證考試重點 📖 目錄 第一章:Vue 3 基礎入門 1.1 什麼是 Vue.js? 1.2 開發環境建置 1.3 第一個 Vue 3 應用 1.4 專案應用指引 1.5 認證考點提示 第二章:Composition API 深入 2.1 setup() 函數詳解 2.2 組合式函數 (Composables) 2.3 進階組合式函數範例 2.4 專案應用指引 2.5 認證考點提示 第三章:響應式系統 3.1 ref() 與 reactive() 詳解 3.2 深度響應式與淺層響應式 3.3 computed() 計算屬性 3.4 watch() 與 watchEffect() 3.5 響應式工具函數 3.6 專案應用指引 3.7 認證考點提示 第四章:模板語法與指令 ...

October 31, 2025 · 56 min · 11798 words · Eric Cheng

物件導向分析與設計 (OOAD) 教學

物件導向分析與設計 (OOAD) 教學手冊 作者: 系統架構師團隊 更新日期: 2025年9月1日 適用對象: 新進開發同仁 版本: v1.0 📚 目錄 前言與學習目標 1.1 為什麼要學習 OOAD? 1.2 學習目標 1.3 學習路徑 1.4 前置知識 OOAD 基礎概念 2.1 什麼是物件導向? 2.2 核心概念詳解 2.3 OOAD 的設計原則 2.4 實務案例:學生管理系統 2.5 章節小結 OOAD 開發流程 3.1 OOAD 流程概覽 3.2 階段一:需求分析 3.3 階段二:系統分析 3.4 階段三:系統設計 3.5 階段四:詳細設計 3.6 階段五:程式實作 3.7 階段六:測試與驗證 3.8 章節小結 UML 與 OOAD 的關係 4.1 UML 簡介 4.2 UML 圖形分類 4.3 核心 UML 圖形詳解 4.4 UML 工具與最佳實務 4.5 章節小結 專案實務應用範例 5.1 專案背景:大學課程管理系統 5.2 階段一:需求分析與 Use Case 設計 5.3 階段二:領域分析與建模 5.4 階段三:架構設計 5.5 階段四:詳細設計 5.6 階段五:關鍵循序圖 5.7 實作關鍵功能 5.8 章節小結 常見錯誤與最佳實務 6.1 分析階段常見錯誤 6.2 設計階段常見錯誤 6.3 實作階段常見錯誤 6.4 UML 建模最佳實務 6.5 程式碼品質準則 6.6 效能與安全性考量 6.7 章節小結 UML 認證考試重點 ...

October 31, 2025 · 69 min · 14535 words · Eric Cheng

統一建模語言(UML)教學

統一建模語言(UML)教學手冊 目錄 UML 基礎概念 1.1 什麼是 UML? 1.2 UML 的用途與價值 1.3 UML 圖表分類 1.4 實務注意事項 常用 UML 圖表教學 2.1 用例圖(Use Case Diagram) 2.2 類別圖(Class Diagram) 2.3 序列圖(Sequence Diagram) 2.4 活動圖(Activity Diagram) 2.5 狀態圖(State Diagram) 2.6 元件圖(Component Diagram) 2.7 部署圖(Deployment Diagram) 實務應用情境 3.1 專案生命週期中的 UML 應用 3.2 不同專案類型的 UML 選擇 3.3 團隊協作中的 UML 專案實作指引 4.1 UML 建模流程 4.2 我們專案中的 UML 應用範例 4.3 建模最佳實務 工具介紹 5.1 常用 UML 工具比較 5.2 PlantUML 詳細介紹 5.3 在我們專案中整合 UML 工具 實務範例:學生管理系統 6.1 專案背景 6.2 Step-by-Step UML 建模 6.3 架構設計 - 元件圖 6.4 部署建模 - 部署圖 6.5 其他領域實務範例 6.6 跨領域建模經驗總結 認證考試準備 7.1 OMG UML 認證概述 7.2 考試重點知識 7.3 學習路線圖 7.4 考試技巧 附錄 ...

October 31, 2025 · 26 min · 5342 words · Eric Cheng

資料流程圖(DFD)教學

資料流程圖 (Data Flow Diagram, DFD) 教學手冊 📋 文件資訊 建立日期: 2025年9月1日 適用對象: 新進專案開發同仁、系統分析初學者 更新版本: v1.1 文件目的: 提供完整的DFD學習指引,從基礎概念到實務應用 🎯 學習路徑建議 初學者路徑 (2-3週) 第1週: 基礎概念建立 - 閱讀第1章:基礎概念 - 閱讀第2章:DFD元素與符號 - 練習:繪製簡單的Context Diagram 第2週: 技能實作 - 閱讀第3章:DFD層次架構 - 閱讀第4章:繪製步驟與方法 - 練習:完成圖書館管理系統案例 第3週: 綜合應用 - 閱讀第6章:練習與案例 - 完成ATM提款系統和訂單管理系統 - 使用第9章檢查清單驗證作品 進階學習者路徑 (1-2週) 第1週: 實務應用 - 快速複習第1-3章基礎概念 - 深入學習第5章:專案實務應用 - 實作中小企業進銷存系統案例 第2週: 專業提升 - 學習第7章:認證準備 - 閱讀第8章:附錄資源 - 準備專業認證考試 團隊領導者路徑 (1週) 重點學習: - 第5.4節:版本控制與變更管理 - 第5.5節:團隊協作與溝通 - 第9章:完整檢查清單 - 建立團隊DFD標準和流程 📚 目錄 1. 基礎概念 1.1 什麼是資料流程圖 (DFD) 1.2 DFD的用途與價值 1.3 DFD發展歷史與演進 1.4 在系統分析與程式開發中的角色 2. DFD元素與符號 2.1 外部實體 (External Entity) 2.2 處理程序 (Process) 2.3 資料流 (Data Flow) 2.4 資料儲存 (Data Store) 2.5 符號標準與繪製規範 3. DFD層次架構 3.1 層次概念與原理 3.2 Level 0 - Context Diagram (環境圖) 3.3 Level 1 - 主要功能分解 3.4 Level 2 及更深層次 3.5 分層一致性檢查 3.6 何時停止分解 4. 繪製步驟與方法 4.1 需求蒐集與資料流識別 4.2 系統化繪製流程 4.3 常見錯誤與避免方式 4.4 工具使用與技巧 5. 專案實務應用 5.1 在專案需求分析文件中使用DFD 5.2 讓程式開發與DFD對應 5.3 與ER Model、UML的關聯 5.4 版本控制與變更管理 5.5 團隊協作與溝通 6. 練習與案例 6.1 案例一:ATM提款系統 6.2 案例二:訂單管理系統 6.3 練習題目 6.4 參考解答 7. 認證準備 7.1 國際/業界常見DFD認證介紹 7.2 必考知識點整理 7.3 考試題型與解題策略 7.4 模擬試題 7.5 考試準備策略 8. 附錄 8.1 常用繪圖工具介紹 8.2 進一步學習資源 8.3 業界最佳實務參考 8.4 社群與論壇 9. 檢查清單 9.1 DFD繪製檢查清單 9.2 品質保證檢查清單 9.3 文件品質檢查清單 9.4 團隊協作檢查清單 9.5 快速檢查表 (Quick Checklist) 1. 基礎概念 1.1 什麼是資料流程圖 (DFD) 資料流程圖(Data Flow Diagram, DFD) 是一種圖形化建模技術,用來描述資訊系統中資料的流動方向和處理過程。它以視覺化的方式展現系統如何處理資料,從資料的輸入、處理、儲存到輸出的完整流程。 ...

October 31, 2025 · 27 min · 5607 words · Eric Cheng

GitHub使用Hugo建立個人網頁教學

GitHub使用Hugo建立個人網頁教學 文件版本: 1.0 最後更新: 2025年10月15日 適用環境: Windows 10/11 難度等級: ⭐⭐ (初級-中級) 📋 教學大綱 前置條件與工具安裝 建立 Hugo 專案 本機預覽網站 選擇與設定 Hugo Theme 部署到 GitHub Pages 維護與更新內容的流程 設定自訂網域(選用) 檢查清單(Checklist) 🎯 學習目標 完成本教學後,您將能夠: ✅ 在 Windows 環境安裝與設定 Hugo 開發環境 ✅ 建立並預覽 Hugo 靜態網站 ✅ 選擇與客製化 Hugo 主題 ✅ 使用 GitHub Actions 自動部署網站到 GitHub Pages ✅ 維護與更新網站內容 ✅ (選用)設定自訂網域名稱 1. 前置條件與工具安裝 1.1 環境需求 在開始之前,請確認您的環境符合以下需求: 作業系統: Windows 10 或更新版本 網路連線: 穩定的網際網路連線 磁碟空間: 至少 500MB 可用空間 系統權限: 能夠安裝應用程式的權限 1.2 安裝 Git Git 是版本控制工具,用於管理專案程式碼與部署到 GitHub。 1.2.1 安裝步驟 下載 Git for Windows 前往官方網站: https://git-scm.com/download/win 下載最新版本的 Git for Windows 安裝程式 執行安裝程式 雙擊下載的 .exe 檔案 建議使用預設設定,一路點選「Next」 重要選項: 編輯器選擇:建議選擇 “Use Visual Studio Code as Git’s default editor” PATH 環境變數:選擇 “Git from the command line and also from 3rd-party software” 換行字元轉換:選擇 “Checkout Windows-style, commit Unix-style line endings” 驗證安裝 開啟 PowerShell,執行以下指令: git --version 預期輸出類似: git version 2.43.0.windows.1 設定 Git 使用者資訊 git config --global user.name "您的名字" git config --global user.email "your.email@example.com" 1.2.2 流程圖 graph TD A[下載 Git 安裝程式] --> B[執行安裝程式] B --> C[選擇安裝選項] C --> D[完成安裝] D --> E[開啟 PowerShell] E --> F[驗證 git --version] F --> G{版本顯示正確?} G -->|是| H[設定使用者資訊] G -->|否| I[重新安裝] I --> B H --> J[Git 安裝完成] ⚠️ 注意事項 安裝後需要重新開啟 PowerShell 才能使用 git 指令 使用者名稱與 Email 會顯示在您的 Git 提交記錄中 建議使用與 GitHub 帳號相同的 Email 1.3 安裝 Hugo Hugo 是一個快速的靜態網站產生器,使用 Go 語言開發。 安裝方式(使用 Chocolatey) 方法一:使用 Chocolatey(推薦) 安裝 Chocolatey 套件管理器 以系統管理員權限開啟 PowerShell,執行: Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1')) 安裝 Hugo Extended 版本 choco install hugo-extended -y 💡 為什麼選擇 Extended 版本? Extended 版本支援 SCSS/SASS 處理,許多現代主題需要此功能。 驗證安裝 關閉並重新開啟 PowerShell(一般權限即可),執行: hugo version 預期輸出類似: hugo v0.121.1-00b46fed8e47f7bb0a85d7cfc2d9f1356379dca7+extended windows/amd64 BuildDate=2023-12-08T08:47:45Z VendorInfo=gohugoio 方法二:手動下載安裝 前往 Hugo GitHub Releases: https://github.com/gohugoio/hugo/releases 下載 hugo_extended_x.xx.x_windows-amd64.zip 解壓縮到 C:\Hugo\bin 將 C:\Hugo\bin 加入系統 PATH 環境變數 1.3.1 設定流程圖 graph LR A[選擇安裝方式] --> B{Chocolatey 或 手動?} B -->|Chocolatey| C[安裝 Chocolatey] B -->|手動| D[下載 Hugo ZIP] C --> E[choco install hugo-extended] D --> F[解壓縮到 C:\Hugo\bin] F --> G[設定 PATH 環境變數] E --> H[驗證: hugo version] G --> H H --> I{安裝成功?} I -->|是| J[完成] I -->|否| K[檢查 PATH 設定] 1.3.2 注意事項 務必安裝 Extended 版本,而非標準版本 手動安裝時,確認 PATH 環境變數設定正確 某些防毒軟體可能會阻擋 Chocolatey 安裝,需暫時停用 1.4 安裝 VS Code Visual Studio Code 是微軟開發的輕量級程式碼編輯器。 1.4.1 安裝步驟 下載 VS Code 前往官方網站: https://code.visualstudio.com/ 點選 “Download for Windows” 執行安裝程式 雙擊下載的 .exe 檔案 建議勾選的選項: ☑️ 將「透過 Code 開啟」加入 Windows 檔案總管目錄內容功能表 ☑️ 將「透過 Code 開啟」加入 Windows 檔案總管檔案內容功能表 ☑️ 將 Code 註冊為支援的檔案類型編輯器 ☑️ 將 Code 加入 PATH 安裝推薦的擴充套件 開啟 VS Code 後,安裝以下擴充套件(Extensions): Hugo Language and Syntax Support (作者: budparr) Markdown All in One (作者: Yu Zhang) Git Graph (作者: mhutchie) 安裝方式:按 Ctrl+Shift+X 開啟擴充套件面板,搜尋並安裝。 1.4.2 注意事項 VS Code 會自動偵測系統已安裝的 Git 建議啟用自動儲存功能:File > Auto Save 1.5 申請 GitHub 帳號 如果您還沒有 GitHub 帳號,請依照以下步驟申請。 申請步驟 前往 GitHub 官網 網址: https://github.com/ 註冊帳號 點選右上角的 “Sign up” 輸入 Email、密碼、使用者名稱 完成驗證(Captcha) 選擇免費方案(Free) 驗證 Email 登入您的 Email 信箱 點選 GitHub 寄送的驗證連結 完成個人資料設定 建議上傳大頭照 填寫簡介(Bio) 1.5.1 注意事項 GitHub 使用者名稱將成為您的網站網址的一部分:https://username.github.io 使用者名稱一旦設定後更改較為繁瑣,請謹慎選擇 建議使用與工作相關的專業名稱 1.6 環境檢查總覽 完成所有安裝後,請執行以下指令檢查環境: # 檢查 Git git --version # 檢查 Hugo hugo version # 檢查 VS Code(開啟 VS Code) code --version 預期輸出範例: PS C:\Users\YourName> git --version git version 2.43.0.windows.1 PS C:\Users\YourName> hugo version hugo v0.121.1-00b46fed8e47f7bb0a85d7cfc2d9f1356379dca7+extended windows/amd64 BuildDate=2023-12-08T08:47:45Z VendorInfo=gohugoio PS C:\Users\YourName> code --version 1.85.0 0ee08df0cf4527e40edc9aa28f4b5bd38bbff2b2 x64 系統架構圖 graph TB subgraph "開發環境" A[Windows 10/11] B[Git] C[Hugo Extended] D[VS Code] end subgraph "雲端服務" E[GitHub Account] F[GitHub Repository] G[GitHub Pages] end A --> B A --> C A --> D B --> F C --> H[本地網站] H --> F F --> G E --> F style A fill:#e1f5ff style E fill:#fff4e1 style G fill:#e8f5e9 2. 建立 Hugo 專案 2.1 建立專案資料夾 首先,選擇一個適當的位置建立您的 Hugo 專案。 操作步驟 開啟 PowerShell 導航到適當的目錄 # 例如:在 D 槽建立專案 cd D:\developer\repos 使用 Hugo 建立新專案 hugo new site my-website 其中 my-website 是您的專案名稱,可自行更改。 進入專案資料夾 cd my-website 預期輸出結果 Congratulations! Your new Hugo site is created in D:\developer\repos\my-website. Just a few more steps and you're ready to go: 1. Download a theme into the same-named folder. Choose a theme from https://themes.gohugo.io/ or create your own with the "hugo new theme <THEMENAME>" command. 2. Perhaps you want to add some content. You can add single files with "hugo new <SECTIONNAME>\<FILENAME>.<FORMAT>". 3. Start the built-in live server via "hugo server". Visit https://gohugo.io/ for quickstart guide and full documentation. 2.2 專案結構說明 Hugo 專案建立後,會產生以下目錄結構: my-website/ ├── archetypes/ # 內容範本 │ └── default.md ├── assets/ # 需要處理的資源(SCSS、JS 等) ├── content/ # 網站內容(Markdown 文件) ├── data/ # 資料檔案(JSON、YAML、TOML) ├── layouts/ # 自訂版面配置 ├── static/ # 靜態檔案(圖片、CSS、JS) ├── themes/ # 主題資料夾 └── hugo.toml # 網站設定檔(或 config.toml) 各目錄功能說明 目錄/檔案 用途 是否必要 archetypes/ 定義新內容的預設前置資料(Front Matter) ⭐⭐⭐ content/ 存放網站的所有內容文章(Markdown) ⭐⭐⭐⭐⭐ data/ 存放結構化資料供模板使用 ⭐⭐ layouts/ 自訂 HTML 模板覆寫主題 ⭐⭐⭐ static/ 直接複製到網站根目錄的靜態檔案 ⭐⭐⭐⭐ themes/ 安裝的主題 ⭐⭐⭐⭐⭐ hugo.toml 網站主要設定檔 ⭐⭐⭐⭐⭐ 2.3 初始化 Git 儲存庫 將專案加入版本控制管理。 # 初始化 Git git init # 建立 .gitignore 檔案 @" # Hugo 產生的檔案 /public/ /resources/_gen/ /.hugo_build.lock # 作業系統檔案 .DS_Store Thumbs.db # 編輯器檔案 .vscode/ .idea/ *.swp *.swo *~ "@ | Out-File -FilePath .gitignore -Encoding utf8 # 加入所有檔案 git add . # 第一次提交 git commit -m "Initial commit: Hugo site created" 2.3.1 流程圖 graph LR A[hugo new site my-website] --> B[建立專案結構] B --> C[cd my-website] C --> D[git init] D --> E[建立 .gitignore] E --> F[git add .] F --> G[git commit] G --> H[專案建立完成] style H fill:#c8e6c9 2.4 設定基本網站資訊 編輯 hugo.toml(或 config.toml)設定檔。 使用 VS Code 開啟專案 code . 編輯 hugo.toml 找到並編輯 hugo.toml 檔案: baseURL = 'https://yourusername.github.io/' languageCode = 'zh-tw' title = '我的個人網站' theme = '' # 稍後設定 [params] description = "這是我的個人網站,分享技術文章與生活點滴" author = "您的名字" [menu] [[menu.main]] name = "首頁" url = "/" weight = 1 [[menu.main]] name = "文章" url = "/posts/" weight = 2 [[menu.main]] name = "關於" url = "/about/" weight = 3 2.4.1 注意事項 baseURL 需要改成您的 GitHub Pages 網址:https://您的GitHub使用者名稱.github.io/ languageCode 設定為 zh-tw 可支援繁體中文 theme 欄位在安裝主題後填入 2.4.2 實務建議 安全性: 不要在設定檔中儲存敏感資訊(API Keys、密碼等) 效能: 保持設定檔簡潔,避免過多不必要的參數 可維護性: 為每個設定項目加上註解說明用途 3. 本機預覽網站 3.1 啟動 Hugo 開發伺服器 Hugo 內建開發伺服器,支援即時預覽(Live Reload)。 啟動指令 hugo server -D 參數說明: server: 啟動開發伺服器 -D: 顯示草稿(Draft)狀態的文章 3.1.1 預期輸出 Start building sites … hugo v0.121.1-00b46fed8e47f7bb0a85d7cfc2d9f1356379dca7+extended windows/amd64 BuildDate=2023-12-08T08:47:45Z VendorInfo=gohugoio | ZH-TW -------------------+-------- Pages | 3 Paginator pages | 0 Non-page files | 0 Static files | 0 Processed images | 0 Aliases | 0 Sitemaps | 1 Cleaned | 0 Built in 45 ms Environment: "development" Serving pages from memory Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) Press Ctrl+C to stop 3.2 在瀏覽器中預覽 開啟瀏覽器 前往 http://localhost:1313/ 您應該會看到一個空白或基本的網站(尚未安裝主題) 常用的開發伺服器參數 # 顯示草稿文章 hugo server -D # 指定埠號 hugo server --port 8080 # 允許外部存取(區域網路) hugo server --bind 0.0.0.0 --baseURL http://你的IP:1313 # 停用 Fast Render(完整重建) hugo server --disableFastRender # 開啟詳細日誌 hugo server --verbose 3.3 建立第一篇文章 使用指令建立文章 hugo new posts/my-first-post.md 這會在 content/posts/ 目錄下建立 my-first-post.md 檔案。 編輯文章內容 使用 VS Code 開啟 content/posts/my-first-post.md: --- title: "我的第一篇文章" date: 2025-10-15T10:00:00+08:00 draft: false tags: ["Hugo", "部落格"] categories: ["教學"] --- ## 歡迎來到我的部落格! 這是我使用 Hugo 建立的第一篇文章。 ### Hugo 的優點 - 🚀 建置速度極快 - 📝 使用 Markdown 撰寫 - 🎨 豐富的主題選擇 - 🔧 高度可客製化 ### 程式碼範例 ```python def hello_hugo(): print("Hello, Hugo!") hello_hugo() 祝大家使用愉快! Front Matter 說明 Front Matter 是文章開頭的 YAML/TOML 區塊,定義文章的詮釋資料: 欄位 說明 範例 title 文章標題 “我的第一篇文章” date 發布日期 2025-10-15T10:00:00+08:00 draft 是否為草稿 true / false tags 標籤 [“Hugo”, “部落格”] categories 分類 [“教學”] author 作者 “Your Name” description 摘要 “本文介紹…” 3.4 即時預覽更新 儲存文章後,Hugo 會自動重建網站,瀏覽器會自動重新整理顯示最新內容。 開發流程圖 sequenceDiagram participant Dev as 開發者 participant VSCode as VS Code participant Hugo as Hugo Server participant Browser as 瀏覽器 Dev->>VSCode: 編輯 .md 檔案 VSCode->>VSCode: 自動儲存 VSCode->>Hugo: 檔案變更通知 Hugo->>Hugo: 重新建置網站 Hugo->>Browser: WebSocket 推送更新 Browser->>Browser: 自動重新整理 Browser-->>Dev: 顯示最新內容 3.5 停止開發伺服器 在 PowerShell 中按下 Ctrl + C 即可停止伺服器。 3.5.1 注意事項 開發伺服器僅供本地開發使用,不適合正式部署 預設僅監聽 localhost,外部無法存取 修改 hugo.toml 後需要重新啟動伺服器 3.5.2 實務建議 開發習慣: 保持開發伺服器運行,善用即時預覽功能 效能: 大型網站可使用 --disableFastRender 確保完整重建 安全性: 不要在開發伺服器上使用正式環境的 API Key 4. 選擇與設定 Hugo Theme 4.1 選擇適合的主題 Hugo 擁有豐富的主題生態系統,您可以從官方主題庫選擇。 主題推薦 主題名稱 特色 適用情境 難度 PaperMod 極簡、快速、SEO 友善 個人部落格 ⭐⭐ Hugo-Theme-Stack 現代化、多功能 技術部落格 ⭐⭐⭐ Ananke 官方推薦、簡潔 初學者 ⭐ LoveIt 功能豐富、中文支援佳 個人網站 ⭐⭐⭐ Academic/Wowchemy 學術型網站 研究人員、教師 ⭐⭐⭐⭐ 瀏覽主題 前往 Hugo 官方主題庫:https://themes.gohugo.io/ 選擇考量因素 mindmap root((Hugo 主題選擇)) 設計風格 極簡主義 多彩豐富 專業商務 個人創意 功能需求 部落格 作品集 文件網站 電商展示 技術要求 是否需要 Extended 版本 相依套件複雜度 客製化難易度 維護狀態 最後更新時間 Star 數量 Issue 處理速度 文件完整性 4.2 安裝主題(以 PaperMod 為例) 方法一:使用 Git Submodule(推薦) 使用 Git Submodule 可以方便地更新主題。 # 確認在專案根目錄 cd D:\developer\repos\my-website # 加入主題作為 Submodule git submodule add --depth=1 https://github.com/adityatelange/hugo-PaperMod.git themes/PaperMod # 更新 Submodule git submodule update --init --recursive 方法二:直接下載主題 # 下載並解壓縮到 themes 資料夾 # 手動從 GitHub 下載 ZIP 並解壓縮到 themes/PaperMod/ 方法三:使用 Hugo Modules(進階) # 初始化 Hugo Module hugo mod init github.com/yourusername/my-website # 在 hugo.toml 中加入 # [module] # [[module.imports]] # path = "github.com/adityatelange/hugo-PaperMod" 安裝流程圖 graph TD A[選擇安裝方式] --> B{Git Submodule?} B -->|是| C[git submodule add] B -->|否| D{Hugo Modules?} D -->|是| E[hugo mod init + 設定] D -->|否| F[手動下載 ZIP] C --> G[更新 hugo.toml] E --> G F --> G G --> H[設定 theme = 'PaperMod'] H --> I[重啟 hugo server] I --> J[檢查網站外觀] style J fill:#c8e6c9 4.3 設定主題 4.3.1 編輯 hugo.toml baseURL = 'https://yourusername.github.io/' languageCode = 'zh-tw' title = '我的技術部落格' theme = 'PaperMod' # 啟用 emoji 支援 enableEmoji = true # 設定摘要長度 summaryLength = 70 # 設定分頁 paginate = 10 [params] # 網站描述 description = "分享程式開發、技術學習與生活心得" # 作者資訊 author = "Your Name" # 顯示閱讀時間 ShowReadingTime = true # 顯示分享按鈕 ShowShareButtons = true # 顯示文章目錄 ShowToc = true TocOpen = false # 顯示程式碼複製按鈕 ShowCodeCopyButtons = true # 首頁資訊 [params.homeInfoParams] Title = "歡迎來到我的部落格 👋" Content = """ 這裡分享我的技術學習筆記、專案經驗與生活點滴。 - 🔧 主要技術: Java, Python, Go - 📚 專注領域: 後端開發、DevOps - 💡 持續學習中... """ # 社群媒體連結 [[params.socialIcons]] name = "github" url = "https://github.com/yourusername" [[params.socialIcons]] name = "linkedin" url = "https://linkedin.com/in/yourprofile" [[params.socialIcons]] name = "email" url = "mailto:your.email@example.com" # 選單設定 [menu] [[menu.main]] identifier = "home" name = "首頁" url = "/" weight = 10 [[menu.main]] identifier = "posts" name = "文章" url = "/posts/" weight = 20 [[menu.main]] identifier = "archives" name = "歸檔" url = "/archives/" weight = 30 [[menu.main]] identifier = "tags" name = "標籤" url = "/tags/" weight = 40 [[menu.main]] identifier = "about" name = "關於" url = "/about/" weight = 50 # 語法高亮設定 [markup] [markup.highlight] style = "monokai" lineNos = true lineNumbersInTable = true noClasses = false 4.4 建立必要頁面 建立關於頁面 hugo new about.md 編輯 content/about.md: --- title: "關於我" date: 2025-10-15 draft: false ShowToc: false --- ## 👨‍💻 自我介紹 哈囉!我是 [Your Name],是一位熱愛技術的軟體工程師。 ### 技能 - **程式語言**: Java, Python, JavaScript - **框架**: Spring Boot, Django, React - **工具**: Git, Docker, Jenkins ### 興趣 - 📖 閱讀技術書籍 - 🏃‍♂️ 慢跑 - 📷 攝影 ### 聯絡方式 - Email: your.email@example.com - GitHub: [@yourusername](https://github.com/yourusername) 建立歸檔頁面 hugo new archives.md 編輯 content/archives.md: --- title: "文章歸檔" layout: "archives" url: "/archives/" summary: archives --- 4.5 客製化主題樣式(選用) 覆寫 CSS 建立 assets/css/extended/custom.css: /* 自訂顏色 */ :root { --primary: #1e88e5; --secondary: #424242; } /* 自訂標題樣式 */ .post-title { font-size: 2rem; font-weight: 700; } /* 自訂程式碼區塊 */ .highlight { border-radius: 8px; padding: 1rem; } /* 響應式調整 */ @media (max-width: 768px) { .post-title { font-size: 1.5rem; } } 覆寫部分模板 如需客製化 HTML 結構,可在 layouts/ 資料夾中覆寫主題檔案: layouts/ ├── _default/ │ └── single.html # 覆寫單篇文章版面 ├── partials/ │ └── footer.html # 覆寫頁尾 └── shortcodes/ └── youtube.html # 自訂 shortcode 4.6 驗證主題設定 重啟開發伺服器 # 停止目前的 server (Ctrl+C) # 重新啟動 hugo server -D 檢查項目 ✅ 網站外觀符合主題風格 ✅ 選單項目正確顯示 ✅ 社群媒體圖示正常 ✅ 文章列表正確顯示 ✅ 語法高亮運作正常 ✅ 響應式設計在手機上正常 主題設定流程總覽 graph TB A[瀏覽主題庫] --> B[選擇適合主題] B --> C[使用 Git Submodule 安裝] C --> D[編輯 hugo.toml 設定] D --> E[建立必要頁面] E --> F{需要客製化?} F -->|是| G[建立自訂 CSS/Template] F -->|否| H[完成主題設定] G --> H H --> I[重啟 hugo server 驗證] style H fill:#c8e6c9 4.6.1 注意事項 不同主題的設定參數可能不同,請參考主題的官方文件 使用 Git Submodule 時,更新主題需使用 git submodule update --remote 客製化前建議先備份原始主題檔案 過度客製化可能導致主題更新困難 4.6.2 實務建議 選擇策略: 優先選擇維護活躍、文件完整的主題 效能考量: 避免選擇過於臃腫、載入緩慢的主題 SEO 優化: 確認主題支援 Open Graph、Twitter Cards 等 meta 標籤 可維護性: 使用覆寫(override)方式客製化,而非直接修改主題檔案 5. 部署到 GitHub Pages 5.1 建立 GitHub Repository 步驟說明 登入 GitHub 前往 https://github.com 並登入 建立新的 Repository 點選右上角的 + 號 選擇 “New repository” Repository 設定 Repository name: yourusername.github.io ⚠️ 必須使用 使用者名稱.github.io 格式 Description: “My personal website built with Hugo” Public: 選擇 Public(免費用戶只能使用 Public repo 的 GitHub Pages) 不要勾選: Initialize this repository with a README 建立 Repository 點選 “Create repository” Repository 命名規則 graph LR A[GitHub 使用者名稱] --> B[yourusername] B --> C[Repository 名稱] C --> D[yourusername.github.io] D --> E[網站網址] E --> F[https://yourusername.github.io] style F fill:#e1f5ff 5.2 連結本地專案與遠端 Repository 在專案目錄中執行以下指令: # 設定遠端 Repository git remote add origin https://github.com/yourusername/yourusername.github.io.git # 檢查遠端設定 git remote -v # 建立主分支(如果尚未建立) git branch -M main # 第一次推送 git push -u origin main 5.2.1 預期輸出 Enumerating objects: 15, done. Counting objects: 100% (15/15), done. Delta compression using up to 8 threads Compressing objects: 100% (10/10), done. Writing objects: 100% (15/15), 2.50 KiB | 2.50 MiB/s, done. Total 15 (delta 0), reused 0 (delta 0), pack-reused 0 To https://github.com/yourusername/yourusername.github.io.git * [new branch] main -> main Branch 'main' set up to track remote branch 'main' from 'origin'. 5.3 設定 GitHub Actions 自動部署 GitHub Actions 可以自動建置並部署 Hugo 網站。 建立 Workflow 檔案 建立 .github/workflows/hugo.yml 檔案: # 建立目錄 New-Item -ItemType Directory -Force -Path .github\workflows # 建立 workflow 檔案 New-Item -ItemType File -Path .github\workflows\hugo.yml 編輯 hugo.yml 使用 VS Code 開啟 .github/workflows/hugo.yml 並貼上以下內容: name: Deploy Hugo site to Pages on: # 當推送到 main 分支時觸發 push: branches: - main # 允許手動觸發 workflow_dispatch: # 設定 GitHub Pages 的權限 permissions: contents: read pages: write id-token: write # 避免同時執行多個部署 concurrency: group: "pages" cancel-in-progress: false # 預設使用 bash defaults: run: shell: bash jobs: # 建置工作 build: runs-on: ubuntu-latest env: HUGO_VERSION: 0.121.1 steps: - name: Install Hugo CLI run: | wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \ && sudo dpkg -i ${{ runner.temp }}/hugo.deb - name: Install Dart Sass run: sudo snap install dart-sass - name: Checkout uses: actions/checkout@v4 with: submodules: recursive fetch-depth: 0 - name: Setup Pages id: pages uses: actions/configure-pages@v4 - name: Install Node.js dependencies run: "[[ -f package-lock.json || -f npm-shrinkwrap.json ]] && npm ci || true" - name: Build with Hugo env: # For maximum backward compatibility with Hugo modules HUGO_ENVIRONMENT: production HUGO_ENV: production run: | hugo \ --gc \ --minify \ --baseURL "${{ steps.pages.outputs.base_url }}/" - name: Upload artifact uses: actions/upload-pages-artifact@v2 with: path: ./public # 部署工作 deploy: environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} runs-on: ubuntu-latest needs: build steps: - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v3 Workflow 檔案說明 區段 說明 on.push.branches 觸發條件:推送到 main 分支 permissions 授予 workflow 必要的權限 jobs.build 建置工作:安裝 Hugo、建置網站 jobs.deploy 部署工作:將產生的檔案部署到 GitHub Pages HUGO_VERSION 指定 Hugo 版本(建議與本地相同) 5.4 設定 GitHub Pages 在 GitHub 網站上設定 前往您的 Repository 頁面 點選 Settings 在左側選單選擇 Pages 在 “Build and deployment” 區段: Source: 選擇 “GitHub Actions” 儲存設定 5.4.1 設定流程圖 graph TD A[進入 Repository Settings] --> B[選擇 Pages] B --> C[Source 選擇 GitHub Actions] C --> D[儲存設定] D --> E[等待 Workflow 執行] E --> F{部署成功?} F -->|是| G[訪問 username.github.io] F -->|否| H[檢查 Actions 錯誤訊息] H --> I[修正問題] I --> J[重新推送] J --> E style G fill:#c8e6c9 5.5 推送並觸發部署 # 加入 GitHub Actions workflow git add .github/workflows/hugo.yml # 提交變更 git commit -m "Add GitHub Actions workflow for Hugo deployment" # 推送到 GitHub git push origin main 5.6 監控部署狀態 查看 Actions 執行狀態 前往 Repository 頁面 點選 Actions 標籤 查看最新的 workflow 執行狀態 部署成功標誌 ✅ build 工作完成 ✅ deploy 工作完成 ✅ 顯示綠色勾勾 訪問您的網站 部署成功後,前往 https://yourusername.github.io/ 查看您的網站! 5.7 部署流程完整視圖 sequenceDiagram participant Dev as 開發者 participant Local as 本地 Git participant GitHub as GitHub Repo participant Actions as GitHub Actions participant Pages as GitHub Pages participant User as 訪客 Dev->>Local: git commit & push Local->>GitHub: 推送程式碼 GitHub->>Actions: 觸發 Workflow Actions->>Actions: 安裝 Hugo Actions->>Actions: 建置網站 (hugo build) Actions->>Actions: 產生 public/ 目錄 Actions->>Pages: 部署靜態檔案 Pages->>Pages: 網站上線 User->>Pages: 訪問網站 Pages->>User: 回傳網頁內容 5.8 常見部署問題與解決方案 問題 1: Workflow 執行失敗 原因: Hugo 版本不匹配或主題問題 解決方案: # 檢查本地 Hugo 版本 hugo version # 在 hugo.yml 中設定相同版本 env: HUGO_VERSION: 0.121.1 # 與本地版本一致 問題 2: 主題無法載入 原因: Git Submodule 未正確同步 解決方案: # 在 Checkout 步驟中確保包含 - name: Checkout uses: actions/checkout@v4 with: submodules: recursive # 重要! fetch-depth: 0 問題 3: baseURL 設定錯誤 原因: hugo.toml 中的 baseURL 不正確 解決方案: # hugo.toml baseURL = 'https://yourusername.github.io/' # 結尾要有斜線 問題 4: CSS/JS 無法載入 原因: 相對路徑問題 解決方案: # 在 Build with Hugo 步驟中使用正確的 baseURL run: | hugo \ --gc \ --minify \ --baseURL "${{ steps.pages.outputs.base_url }}/" 5.9 效能優化建議 啟用快取 在 workflow 中加入快取步驟: - name: Cache Hugo resources uses: actions/cache@v3 with: path: resources key: ${{ runner.os }}-hugo-resources-${{ hashFiles('content/**') }} 圖片優化 # 使用 Hugo 的圖片處理功能 # 在文章中使用 Hugo 的 image processing 在 Markdown 中: 啟用 CDN(選用) 考慮使用 Cloudflare Pages 或其他 CDN 服務提升全球存取速度。 5.7.1 注意事項 GitHub Pages 有 1GB 儲存空間限制 每月頻寬限制 100GB 部署次數建議不要過於頻繁(每小時不超過 10 次) 私有 Repository 需要 GitHub Pro 方案才能使用 Pages 5.7.2 實務建議 安全性: 不要在 Repository 中儲存敏感資訊(API Keys、密碼) 效能: 使用圖片壓縮工具減少檔案大小 SEO: 確保 sitemap.xml 和 robots.txt 正確設定 可維護性: 定期更新 Hugo 版本和主題 6. 維護與更新內容的流程 6.1 日常更新工作流程 建立文章並部署的標準流程如下: 標準工作流程 graph TD A[開啟 VS Code] --> B[啟動 hugo server -D] B --> C[建立新文章] C --> D[撰寫內容] D --> E[本機預覽] E --> F{內容滿意?} F -->|否| D F -->|是| G[設定 draft: false] G --> H[git add .] H --> I[git commit -m 訊息] I --> J[git push origin main] J --> K[GitHub Actions 自動部署] K --> L[網站更新完成] style L fill:#c8e6c9 詳細步驟 步驟 1: 建立新文章 # 建立新文章 hugo new posts/2025/my-new-post.md # 或使用日期目錄結構 hugo new posts/2025-10-15-my-new-post.md 步驟 2: 編輯文章內容 --- title: "深入理解 Java Stream API" date: 2025-10-15T14:30:00+08:00 draft: false tags: ["Java", "Stream API", "函數式編程"] categories: ["程式設計"] author: "Your Name" description: "本文詳細介紹 Java 8 引入的 Stream API,包含常用操作與最佳實踐" cover: image: "images/java-stream.png" alt: "Java Stream API" caption: "Stream API 讓集合操作更優雅" --- ## 前言 Java 8 引入的 Stream API 徹底改變了集合處理的方式... ## 基本概念 Stream 是一個資料序列,支援各種操作來處理資料... ### 建立 Stream \`\`\`java // 從集合建立 List<String> list = Arrays.asList("a", "b", "c"); Stream<String> stream = list.stream(); // 從陣列建立 String[] array = {"a", "b", "c"}; Stream<String> stream2 = Arrays.stream(array); \`\`\` ## 常用操作 ### Filter(過濾) \`\`\`java list.stream() .filter(s -> s.startsWith("a")) .collect(Collectors.toList()); \`\`\` ## 總結 Stream API 提供了簡潔且高效的集合處理方式... 步驟 3: 本機預覽 # 如果 server 未啟動,執行 hugo server -D # 在瀏覽器開啟 http://localhost:1313/ 步驟 4: 提交並部署 # 檢查變更 git status # 加入所有變更 git add . # 提交(使用有意義的訊息) git commit -m "新增文章: 深入理解 Java Stream API" # 推送到 GitHub git push origin main 步驟 5: 等待部署完成 前往 GitHub Repository 的 Actions 頁面 確認 workflow 執行成功 訪問網站確認更新 6.2 Git 提交訊息最佳實踐 提交訊息格式 <類型>: <簡短描述> <詳細描述(選用)> <相關 Issue(選用)> 常用類型 類型 說明 範例 feat 新功能 feat: 新增留言功能 post 新文章 post: 新增 Java Stream API 教學 fix 修正錯誤 fix: 修正文章日期顯示問題 style 樣式調整 style: 更新首頁配色 docs 文件更新 docs: 更新 README refactor 重構 refactor: 重新組織文章分類 config 設定變更 config: 更新 hugo.toml 設定 範例 # 好的提交訊息 git commit -m "post: 新增 Docker 容器化部署教學" git commit -m "fix: 修正文章中程式碼區塊的語法高亮" git commit -m "style: 調整文章標題字體大小" # 不好的提交訊息(避免) git commit -m "update" git commit -m "fix bug" git commit -m "change" 6.3 管理草稿文章 草稿工作流程 stateDiagram-v2 [*] --> 草稿: hugo new post.md 草稿 --> 預覽: hugo server -D 預覽 --> 草稿: 繼續編輯 預覽 --> 發布: draft: false 發布 --> 線上: git push 線上 --> [*] 草稿文章不會被部署 --- title: "我的草稿文章" date: 2025-10-15 draft: true # 設為 true,不會出現在正式網站 --- 本機預覽草稿 # 包含草稿的預覽 hugo server -D # 不包含草稿的預覽(模擬正式環境) hugo server 將草稿變為正式文章 只需將 draft: true 改為 draft: false: ...

October 15, 2025 · 21 min · 4413 words · Eric Cheng

Maven 使用教學

Maven 使用教學手冊 文件資訊 版本: 3.0.0 建立日期: 2025年8月29日 最後更新: 2025年7月 適用對象: 新進開發同仁 目的: 協助快速熟悉並在專案中正確使用 Maven 目錄 Maven 基本介紹 1.1 什麼是 Maven? 1.2 Maven 的用途與優勢 1.3 在專案中的角色 環境建置 2.1 前置條件 2.2 Maven 安裝 2.3 驗證安裝成功 2.4 IDE 整合 2.5 設定檔配置 Maven 專案結構 3.1 標準目錄結構 3.2 目錄結構詳細說明 3.3 在專案中的實際應用 3.4 自訂目錄結構 pom.xml 說明 4.1 什麼是 POM? 4.2 基本結構 4.3 常用標籤詳細說明 4.4 如何新增與管理依賴 4.5 建置配置 4.6 我們專案的完整 pom.xml 分析 常用指令 5.1 Maven 生命週期 5.2 基本指令詳解 5.3 依賴管理指令 5.4 執行指令 5.5 資訊查詢指令 5.6 進階指令 5.7 我們專案中的常用工作流程 5.8 VS Code 中的 Maven 整合 5.9 Maven Wrapper 使用 5.10 與 CI/CD 整合 專案最佳實務 6.1 依賴管理建議 6.2 Docker 整合 6.3 安全性管理 6.4 效能監控 6.5 現代化開發實務 6.6 效能優化策略 6.7 微服務架構支援 6.8 避免版本衝突的方法 6.9 建置優化策略 6.10 程式碼品質管理 6.11 使用公司內部 Nexus/Artifactory 6.12 環境特定設定 常見問題排解 FAQ 7.1 編譯相關問題 7.2 依賴相關問題 7.3 測試相關問題 7.4 IDE 整合問題 7.5 效能相關問題 7.6 網路相關問題 7.7 專案中注意事項 附錄 8.1 官方文件與教學資源連結 8.2 常用插件參考 8.3 Maven 生命週期詳細說明 8.4 常用 Maven 屬性 8.5 範例設定檔 8.6 團隊協作指南 檢查清單 Checklist 9.1 環境設定檢查清單 9.2 日常開發檢查清單 9.3 問題排解檢查清單 9.4 發布準備檢查清單 9.5 新人上手檢查清單 9.6 定期維護檢查清單 快速參考手冊 10.1 常用指令速查表 10.2 常用參數速查表 10.3 POM 檔案基本結構速查 10.4 常見問題快速解決 10.5 開發工作流程檢查清單 10.6 實用技巧 進階主題 11.1 自定義 Maven Archetype 11.2 Maven 插件開發 11.3 Maven 與 Spring Boot 整合 11.4 Maven 與容器化部署 11.5 企業級 Maven 倉庫管理 團隊協作與規範 12.1 程式碼審查規範 12.2 版本管理策略 12.3 分支管理與 Maven 12.4 自動化測試策略 Maven 與現代 Java 開發 13.1 Java 模組系統(JPMS)與 Maven 13.2 Maven 與 JDK 版本管理 13.3 Maven 與記錄(Records)和文字區塊 13.4 Maven 與虛擬執行緒 13.5 Maven 4 預覽與未來展望 效能調校與監控 14.1 Maven 建置效能優化 14.2 依賴解析效能調校 14.3 建置時間監控與分析 14.4 記憶體使用最佳化 錯誤處理與除錯技巧 15.1 常見錯誤診斷流程 15.2 除錯工具與技巧 15.3 日誌分析與解讀 15.4 遠端除錯設定 實戰專案範例 16.1 簡單控制台應用程式 16.2 Spring Boot Web 應用程式 16.3 多模組企業級專案 16.4 微服務架構專案 1. Maven 基本介紹 1.1 什麼是 Maven? Apache Maven 是一個專案管理和建置自動化工具,主要用於 Java 專案(也支援其他語言如 C#、Ruby、Scala 等)。Maven 使用專案物件模型(Project Object Model, POM)來管理專案的建置、報告和文件。 ...

July 15, 2025 · 38 min · 8024 words · Eric Cheng