23 KiB
按照以下步驟開始使用這些資源:
- 分叉此倉庫:點擊
- 克隆此倉庫:
git clone https://github.com/microsoft/Web-Dev-For-Beginners.git
- 加入 Azure AI Foundry Discord,與專家和其他開發者交流
初學者的網頁開發課程 - 一套完整的課程
透過 Microsoft Cloud Advocates 提供的 12 週全面課程,學習網頁開發的基礎知識。每個 24 節課程都透過實作項目(如生態瓶、瀏覽器擴展和太空遊戲)深入探討 JavaScript、CSS 和 HTML。參與測驗、討論和實際作業,提升技能並加強知識記憶。立即開始您的程式設計旅程吧!
🧑🎓 您是學生嗎?
造訪 學生中心頁面,您可以找到初學者資源、學生套件,甚至獲得免費證書兌換券的方法。這是您想要收藏並定期查看的頁面,因為我們每月都會更新內容。
📣 公告 - 新的課程 關於 JavaScript 的生成式 AI 已經發布
不要錯過我們的生成式 AI 新課程!
造訪 https://aka.ms/genai-js-course 開始學習!

- 課程涵蓋從基礎到 RAG 的所有內容。
- 使用生成式 AI 和我們的伴侶應用程式與歷史人物互動。
- 有趣且引人入勝的敘事,您將進行時光旅行!

每節課都包含作業、知識檢查和挑戰,幫助您學習以下主題:
- 提示設計與提示工程
- 文本與圖像應用程式生成
- 搜索應用程式
造訪 https://aka.ms/genai-js-course 開始學習!
🌱 開始使用
學習者,每節課開始前,先進行課前測驗,然後閱讀課程材料,完成各種活動,並透過課後測驗檢查您的理解。
為了提升學習體驗,與同伴一起完成項目吧!我們鼓勵您在討論論壇中交流,我們的版主團隊將隨時回答您的問題。
為了進一步提升您的教育,我們強烈建議探索 Microsoft Learn 以獲取更多學習材料。
📋 設置您的環境
此課程已準備好開發環境!開始時,您可以選擇在 Codespace(基於瀏覽器,無需安裝的環境)中運行課程,或在本地電腦上使用如 Visual Studio Code 的文本編輯器。
創建您的倉庫
為了方便保存您的工作,建議您創建此倉庫的副本。您可以點擊頁面頂部的 使用此模板 按鈕,這將在您的 GitHub 帳戶中創建一個包含課程副本的新倉庫。
按照以下步驟:
- 分叉此倉庫:點擊頁面右上角的 "Fork" 按鈕。
- 克隆此倉庫:
git clone https://github.com/microsoft/Web-Dev-For-Beginners.git
在 Codespace 中運行課程
在您創建的倉庫副本中,點擊 Code 按鈕並選擇 Open with Codespaces。這將為您創建一個新的 Codespace 以供使用。

在本地電腦上運行課程
要在本地電腦上運行此課程,您需要一個文本編輯器、瀏覽器和命令行工具。我們的第一節課 程式語言與工具介紹 將引導您選擇適合您的工具。
我們推薦使用 Visual Studio Code 作為編輯器,它還內建了 終端。您可以在這裡下載 Visual Studio Code。
-
將倉庫克隆到您的電腦。您可以點擊 Code 按鈕並複製 URL:
然後,在 Visual Studio Code 的 終端 中運行以下命令,將
<your-repository-url>
替換為您剛複製的 URL:git clone <your-repository-url>
-
在 Visual Studio Code 中打開文件夾。您可以點擊 文件 > 打開文件夾,然後選擇您剛克隆的文件夾。
推薦的 Visual Studio Code 擴展:
- Live Server - 在 Visual Studio Code 中預覽 HTML 頁面
- Copilot - 幫助您更快地編寫程式碼
📂 每節課包含:
- 可選的手繪筆記
- 可選的補充視頻
- 課前熱身測驗
- 書面課程
- 對於基於項目的課程,提供逐步指南以完成項目
- 知識檢查
- 挑戰
- 補充閱讀
- 作業
- 課後測驗
關於測驗的說明:所有測驗都包含在 Quiz-app 文件夾中,共有 48 個測驗,每個測驗包含三個問題。它們可在這裡找到,測驗應用程式可以在本地運行或部署到 Azure;請按照
quiz-app
文件夾中的指示操作。
🗃️ 課程
項目名稱 | 教授概念 | 學習目標 | 連結課程 | 作者 | |
---|---|---|---|---|---|
01 | 開始使用 | 程式語言與工具介紹 | 學習大多數程式語言的基本原理以及幫助專業開發者完成工作的軟體 | 程式語言與工具介紹 | Jasmine |
02 | 開始使用 | GitHub 基礎,包含團隊合作 | 學習如何在項目中使用 GitHub,以及如何與他人協作代碼庫 | GitHub 基礎 | Floor |
03 | 開始使用 | 無障礙性 | 學習網頁無障礙性的基礎知識 | 無障礙性基礎 | Christopher |
04 | JS 基礎 | JavaScript 資料類型 | JavaScript 資料類型的基礎知識 | 資料類型 | Jasmine |
05 | JS 基礎 | 函數與方法 | 學習如何使用函數與方法管理應用程式的邏輯流程 | 函數與方法 | Jasmine 和 Christopher |
06 | JS 基礎 | 使用 JS 做出決策 | 學習如何使用決策方法在代碼中創建條件 | 做出決策 | Jasmine |
07 | JS 基礎 | 陣列與迴圈 | 使用 JavaScript 中的陣列與迴圈處理資料 | 陣列與迴圈 | Jasmine |
08 | 生態瓶 | HTML 實作 | 建立 HTML 以創建線上生態瓶,專注於建立佈局 | HTML 介紹 | Jen |
09 | 生態瓶 | CSS 實作 | 建立 CSS 以設計線上生態瓶,專注於 CSS 的基礎知識,包括使頁面響應式 | CSS 介紹 | Jen |
10 | Terrarium | JavaScript 閉包、DOM 操作 | 建立 JavaScript 使生態瓶具備拖放介面的功能,重點在於閉包與 DOM 操作 | JavaScript 閉包、DOM 操作 | Jen |
11 | Typing Game | 建立打字遊戲 | 學習如何使用鍵盤事件來驅動 JavaScript 應用程式的邏輯 | 事件驅動程式設計 | Christopher |
12 | Green Browser Extension | 瀏覽器操作 | 學習瀏覽器的運作方式、歷史,以及如何搭建瀏覽器擴充功能的基本架構 | 關於瀏覽器 | Jen |
13 | Green Browser Extension | 建立表單、呼叫 API 並將變數儲存在本地儲存中 | 建立瀏覽器擴充功能的 JavaScript 元素,使用儲存在本地儲存中的變數來呼叫 API | API、表單與本地儲存 | Jen |
14 | Green Browser Extension | 瀏覽器中的背景處理與網頁效能 | 使用瀏覽器的背景處理來管理擴充功能的圖示;學習網頁效能以及一些優化方法 | 背景任務與效能 | Jen |
15 | Space Game | 更進階的 JavaScript 遊戲開發 | 學習使用類別與組合的繼承,以及發布/訂閱模式,為建立遊戲做準備 | 進階遊戲開發介紹 | Chris |
16 | Space Game | 繪製到 Canvas | 學習使用 Canvas API,將元素繪製到螢幕上 | 繪製到 Canvas | Chris |
17 | Space Game | 在螢幕上移動元素 | 探索如何使用笛卡爾座標與 Canvas API 讓元素產生移動 | 移動元素 | Chris |
18 | Space Game | 碰撞檢測 | 使用按鍵事件讓元素碰撞並互相反應,並提供冷卻功能以確保遊戲效能 | 碰撞檢測 | Chris |
19 | Space Game | 計分 | 根據遊戲的狀態與表現進行數學計算 | 計分 | Chris |
20 | Space Game | 結束與重新開始遊戲 | 學習如何結束與重新開始遊戲,包括清理資源與重置變數值 | 結束條件 | Chris |
21 | Banking App | 網頁應用程式中的 HTML 模板與路由 | 學習如何使用路由與 HTML 模板來搭建多頁網站的架構 | HTML 模板與路由 | Yohan |
22 | Banking App | 建立登入與註冊表單 | 學習如何建立表單並處理驗證邏輯 | 表單 | Yohan |
23 | Banking App | 獲取與使用資料的方法 | 學習資料如何在應用程式中流動,如何獲取、儲存與處理資料 | 資料 | Yohan |
24 | Banking App | 狀態管理的概念 | 學習應用程式如何保留狀態以及如何以程式方式管理狀態 | 狀態管理 | Yohan |
🏫 教學理念
我們的課程設計基於兩個關鍵的教學原則:
- 專案導向學習
- 頻繁的小測驗
這個課程教授 JavaScript、HTML 和 CSS 的基礎知識,以及當今網頁開發者使用的最新工具與技術。學生將有機會透過建立打字遊戲、虛擬生態瓶、環保瀏覽器擴充功能、太空侵略者風格的遊戲,以及商業銀行應用程式來獲得實作經驗。到課程結束時,學生將對網頁開發有扎實的理解。
🎓 你可以在 Microsoft Learn 上以 學習路徑 的形式學習本課程的前幾節課!
透過將內容與專案結合,學習過程變得更有趣,並能增強學生對概念的記憶。我們還撰寫了幾個 JavaScript 基礎的入門課程,搭配 "JavaScript 初學者系列" 視頻教程中的影片,其中一些作者也參與了本課程的編寫。
此外,課前的低壓力小測驗能幫助學生專注於學習主題,而課後的第二次測驗則能進一步鞏固記憶。本課程設計靈活且有趣,可以完整學習,也可以部分選修。專案從簡單開始,並在 12 週的課程週期中逐漸變得複雜。
雖然我們刻意避免引入 JavaScript 框架,以專注於成為網頁開發者所需的基本技能,但完成本課程後,學習 Node.js 會是下一個不錯的進階步驟。你可以參考另一系列視頻:"Node.js 初學者系列"。
🧭 離線存取
你可以使用 Docsify 離線運行此文件。Fork 此存儲庫,在本地機器上安裝 Docsify,然後在此存儲庫的根目錄中輸入 docsify serve
。網站將在本地的 3000 埠上運行:localhost:3000
。
所有課程的 PDF 可在這裡找到。
🎒 其他課程
我們的團隊還製作了其他課程!請查看:
- 生成式 AI 初學者課程
- 生成式 AI 初學者課程 .NET
- 使用 JavaScript 的生成式 AI
- 使用 Java 的生成式 AI
- AI 初學者課程
- 資料科學初學者課程
- 機器學習初學者課程
- 網路安全初學者課程
- 網頁開發初學者課程
- 物聯網初學者課程
- XR 開發初學者課程
- 精通 GitHub Copilot 的代理性使用
- 精通 GitHub Copilot 的 C#/.NET 開發者課程
- 選擇你的 Copilot 冒險
授權
此存儲庫採用 MIT 授權。更多資訊請參閱 LICENSE 文件。
免責聲明:
本文件已使用 AI 翻譯服務 Co-op Translator 進行翻譯。雖然我們致力於提供準確的翻譯,但請注意,自動翻譯可能包含錯誤或不準確之處。原始文件的母語版本應被視為權威來源。對於關鍵資訊,建議使用專業人工翻譯。我們對因使用此翻譯而引起的任何誤解或錯誤解釋不承擔責任。