|
|
2 months ago | |
|---|---|---|
| .. | ||
| 1-getting-started-lessons | 2 months ago | |
| 2-js-basics | 2 months ago | |
| 3-terrarium | 2 months ago | |
| 4-typing-game | 3 months ago | |
| 5-browser-extension | 3 months ago | |
| 6-space-game | 3 months ago | |
| 7-bank-project | 3 months ago | |
| 8-code-editor/1-using-a-code-editor | 2 months ago | |
| 9-chat-project | 3 months ago | |
| docs | 3 months ago | |
| lesson-template | 3 months ago | |
| memory-game | 2 months ago | |
| quiz-app | 3 months ago | |
| AGENTS.md | 2 months ago | |
| CODE_OF_CONDUCT.md | 3 months ago | |
| CONTRIBUTING.md | 3 months ago | |
| README.md | 2 months ago | |
| SECURITY.md | 3 months ago | |
| SUPPORT.md | 3 months ago | |
| _404.md | 3 months ago | |
| for-teachers.md | 2 months ago | |
README.md
다음 단계를 따라 이 자료를 시작해보세요:
- 저장소 포크하기: 클릭
- 저장소 클론하기:
git clone https://github.com/microsoft/Web-Dev-For-Beginners.git - Azure AI Foundry Discord에 가입하여 전문가와 다른 개발자들을 만나보세요
초보자를 위한 웹 개발 - 커리큘럼
Microsoft Cloud Advocates가 제공하는 12주간의 종합 코스를 통해 웹 개발의 기초를 배워보세요. 24개의 각 레슨은 테라리움, 브라우저 확장, 우주 게임과 같은 실습 프로젝트를 통해 JavaScript, CSS, HTML을 깊이 있게 탐구합니다. 퀴즈, 토론, 실습 과제를 통해 학습에 참여하고, 프로젝트 기반 학습법으로 기술을 향상시키고 지식을 최적화하세요. 지금 코딩 여정을 시작하세요!
🌐 다국어 지원
GitHub Action을 통한 지원 (자동화 및 항상 최신 상태 유지)
French | Spanish | German | Russian | Arabic | Persian (Farsi) | Urdu | Chinese (Simplified) | Chinese (Traditional, Macau) | Chinese (Traditional, Hong Kong) | Chinese (Traditional, Taiwan) | Japanese | Korean | Hindi | Bengali | Marathi | Nepali | Punjabi (Gurmukhi) | Portuguese (Portugal) | Portuguese (Brazil) | Italian | Polish | Turkish | Greek | Thai | Swedish | Danish | Norwegian | Finnish | Dutch | Hebrew | Vietnamese | Indonesian | Malay | Tagalog (Filipino) | Swahili | Hungarian | Czech | Slovak | Romanian | Bulgarian | Serbian (Cyrillic) | Croatian | Slovenian | Ukrainian | Burmese (Myanmar)
추가 번역을 원하시면 여기에 지원 언어 목록이 있습니다.
🧑🎓 학생이신가요?
학생 허브 페이지를 방문하여 초보자 자료, 학생 팩, 무료 인증서 바우처를 받을 수 있는 방법을 확인하세요. 이 페이지를 즐겨찾기에 추가하고 매달 콘텐츠가 변경될 때마다 확인하세요.
📣 공지 - 생성형 AI를 활용한 새로운 프로젝트
새로운 AI 어시스턴트 프로젝트가 추가되었습니다. 프로젝트를 확인해보세요.
📣 공지 - 새로운 커리큘럼 생성형 AI를 활용한 JavaScript 커리큘럼 출시
새로운 생성형 AI 커리큘럼을 놓치지 마세요!
https://aka.ms/genai-js-course를 방문하여 시작하세요!
- 기초부터 RAG까지 모든 것을 다루는 레슨
- GenAI와 동반 앱을 사용하여 역사적 인물과 상호작용
- 재미있고 몰입감 있는 스토리, 시간 여행을 경험하세요!
각 레슨에는 다음이 포함됩니다:
- 학습 주제에 대한 안내: 프롬프트 및 프롬프트 엔지니어링, 텍스트 및 이미지 앱 생성, 검색 앱
- 과제, 지식 점검, 도전 과제
https://aka.ms/genai-js-course를 방문하여 시작하세요!
🌱 시작하기
학습자, 각 레슨에서 사전 강의 퀴즈로 시작하고 강의 자료를 읽으며 다양한 활동을 완료하세요. 강의 후 퀴즈로 이해도를 확인하세요.
학습 경험을 향상시키기 위해 동료들과 함께 프로젝트를 진행하세요! 토론 포럼에서 질문을 할 수 있으며, 모더레이터 팀이 답변을 제공합니다.
추가 학습을 위해 Microsoft Learn을 탐색하여 추가 자료를 확인하는 것을 추천합니다.
📋 환경 설정하기
이 커리큘럼은 개발 환경이 준비되어 있습니다! 시작할 때 Codespace (브라우저 기반, 설치 필요 없음 환경) 또는 로컬 컴퓨터에서 텍스트 편집기를 사용하여 실행할 수 있습니다. Visual Studio Code를 추천합니다.
저장소 생성하기
작업을 쉽게 저장하려면 이 저장소의 복사본을 생성하는 것이 좋습니다. 페이지 상단의 Use this template 버튼을 클릭하면 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 내의 터미널을 열고, 복사한 URL을
<your-repository-url>로 대체하여 다음 명령을 실행하세요:git clone <your-repository-url> -
Visual Studio Code에서 폴더를 열어보세요. File > Open Folder를 클릭하고 클론한 폴더를 선택하세요.
추천 Visual Studio Code 확장 프로그램:
- Live Server - Visual Studio Code 내에서 HTML 페이지를 미리보기
- Copilot - 코드를 더 빠르게 작성할 수 있도록 도움
📂 각 레슨에는 다음이 포함됩니다:
- 선택적 스케치노트
- 선택적 보충 영상
- 사전 레슨 준비 퀴즈
- 작성된 레슨 자료
- 프로젝트 기반 레슨의 경우, 프로젝트를 구축하는 단계별 가이드
- 지식 점검
- 도전 과제
- 보충 자료
- 과제
- 레슨 후 퀴즈
퀴즈에 대한 참고 사항: 모든 퀴즈는 Quiz-app 폴더에 포함되어 있으며, 총 48개의 퀴즈가 각 3개의 질문으로 구성되어 있습니다. 여기에서 이용할 수 있으며, Quiz 앱은 로컬에서 실행하거나 Azure에 배포할 수 있습니다.
quiz-app폴더의 지침을 따르세요.
🗃️ 강의 목록
| 프로젝트 이름 | 학습 개념 | 학습 목표 | 연결된 강의 | 작성자 | |
|---|---|---|---|---|---|
| 01 | 시작하기 | 프로그래밍 소개 및 개발 도구 | 대부분의 프로그래밍 언어의 기본 원리를 배우고, 전문 개발자가 사용하는 소프트웨어에 대해 알아보기 | 프로그래밍 언어 및 개발 도구 소개 | Jasmine |
| 02 | 시작하기 | GitHub 기본, 팀과 함께 작업하기 | 프로젝트에서 GitHub을 사용하는 방법과 코드베이스에서 다른 사람들과 협업하는 방법 배우기 | GitHub 소개 | Floor |
| 03 | 시작하기 | 접근성 | 웹 접근성의 기본 사항 배우기 | 접근성 기본 | Christopher |
| 04 | JS 기본 | JavaScript 데이터 유형 | JavaScript 데이터 유형의 기본 사항 배우기 | 데이터 유형 | Jasmine |
| 05 | JS 기본 | 함수와 메서드 | 애플리케이션의 논리 흐름을 관리하기 위한 함수와 메서드 배우기 | 함수와 메서드 | Jasmine and Christopher |
| 06 | JS 기본 | JS로 결정 내리기 | 결정 방법을 사용하여 코드에서 조건을 생성하는 방법 배우기 | 결정 내리기 | Jasmine |
| 07 | JS 기본 | 배열과 반복문 | JavaScript에서 배열과 반복문을 사용하여 데이터를 처리하는 방법 배우기 | 배열과 반복문 | Jasmine |
| 08 | 테라리움 | HTML 실습 | 온라인 테라리움을 만들기 위한 HTML 작성, 레이아웃 구축에 중점 | HTML 소개 | Jen |
| 09 | 테라리움 | CSS 실습 | 온라인 테라리움을 스타일링하기 위한 CSS 작성, CSS 기본 사항 및 페이지를 반응형으로 만드는 방법에 중점 | CSS 소개 | Jen |
| 10 | 테라리움 | JavaScript 클로저, DOM 조작 | 테라리움을 드래그/드롭 인터페이스로 작동하게 만드는 JavaScript 작성, 클로저와 DOM 조작에 중점 | JavaScript 클로저, DOM 조작 | Jen |
| 11 | 타이핑 게임 | 타이핑 게임 만들기 | 키보드 이벤트를 사용하여 JavaScript 앱의 논리를 구동하는 방법 배우기 | 이벤트 기반 프로그래밍 | Christopher |
| 12 | 친환경 브라우저 확장 | 브라우저 작업 | 브라우저의 작동 방식, 역사, 브라우저 확장의 첫 번째 요소를 스캐폴딩하는 방법 배우기 | 브라우저 소개 | Jen |
| 13 | 친환경 브라우저 확장 | 폼 작성, API 호출 및 로컬 스토리지에 변수 저장 | 로컬 스토리지에 저장된 변수를 사용하여 API를 호출하는 브라우저 확장의 JavaScript 요소 작성 | API, 폼, 로컬 스토리지 | Jen |
| 14 | 친환경 브라우저 확장 | 브라우저의 백그라운드 프로세스, 웹 성능 | 브라우저의 백그라운드 프로세스를 사용하여 확장의 아이콘을 관리하는 방법 배우기; 웹 성능 및 최적화 방법 배우기 | 백그라운드 작업 및 성능 | Jen |
| 15 | 우주 게임 | JavaScript를 활용한 고급 게임 개발 | 클래스와 구성, Pub/Sub 패턴을 사용한 상속에 대해 배우고 게임 개발 준비하기 | 고급 게임 개발 소개 | Chris |
| 16 | 우주 게임 | 캔버스에 그리기 | 화면에 요소를 그리기 위해 사용되는 Canvas API 배우기 | 캔버스에 그리기 | Chris |
| 17 | 우주 게임 | 화면에서 요소 이동 | 요소가 데카르트 좌표와 Canvas API를 사용하여 움직임을 얻는 방법 배우기 | 요소 이동 | Chris |
| 18 | 우주 게임 | 충돌 감지 | 키 입력을 사용하여 요소가 서로 충돌하고 반응하는 방법 배우기; 게임 성능을 보장하기 위한 쿨다운 기능 제공 | 충돌 감지 | Chris |
| 19 | 우주 게임 | 점수 계산 | 게임 상태와 성능에 따라 수학 계산 수행하기 | 점수 계산 | Chris |
| 20 | 우주 게임 | 게임 종료 및 재시작 | 게임 종료 및 재시작 방법 배우기, 자산 정리 및 변수 값 재설정 포함 | 종료 조건 | Chris |
| 21 | 은행 앱 | 웹 앱에서 HTML 템플릿 및 라우트 | 라우팅 및 HTML 템플릿을 사용하여 다중 페이지 웹사이트의 아키텍처 스캐폴드 작성 방법 배우기 | HTML 템플릿 및 라우트 | Yohan |
| 22 | 은행 앱 | 로그인 및 등록 폼 작성 | 폼 작성 및 유효성 검사 루틴 처리 방법 배우기 | 폼 | Yohan |
| 23 | 은행 앱 | 데이터 가져오기 및 사용 방법 | 앱에서 데이터가 흐르는 방식, 데이터를 가져오고 저장하고 처리하는 방법 배우기 | 데이터 | Yohan |
| 24 | 은행 앱 | 상태 관리 개념 | 앱이 상태를 유지하는 방법과 이를 프로그래밍적으로 관리하는 방법 배우기 | 상태 관리 | Yohan |
| 25 | 브라우저/VScode 코드 | VScode 사용하기 | 코드 편집기 사용 방법 배우기 | VScode 코드 편집기 사용하기 | Chris |
| 26 | AI 어시스턴트 | AI 작업하기 | 나만의 AI 어시스턴트 만들기 배우기 | AI 어시스턴트 프로젝트 | Chris |
🏫 교육 방법론
우리의 커리큘럼은 두 가지 주요 교육 원칙을 기반으로 설계되었습니다:
- 프로젝트 기반 학습
- 빈번한 퀴즈
이 프로그램은 JavaScript, HTML, CSS의 기본 사항과 오늘날 웹 개발자가 사용하는 최신 도구와 기술을 가르칩니다. 학생들은 타이핑 게임, 가상 테라리움, 친환경 브라우저 확장, 우주 침략자 스타일 게임, 비즈니스용 은행 앱을 구축하며 실습 경험을 쌓을 기회를 갖게 됩니다. 시리즈가 끝날 때쯤 학생들은 웹 개발에 대한 탄탄한 이해를 얻게 될 것입니다.
🎓 이 커리큘럼의 첫 몇 강의를 Microsoft Learn에서 학습 경로로 수강할 수 있습니다!
프로젝트와 콘텐츠를 일치시킴으로써 학생들에게 더 흥미로운 학습 경험을 제공하고 개념의 이해도를 높일 수 있습니다. 또한 JavaScript 기본 사항을 소개하는 여러 시작 강의를 작성했으며, "JavaScript 초보자 시리즈" 비디오 튜토리얼 컬렉션과 함께 제공됩니다. 이 튜토리얼의 일부 작성자는 이 커리큘럼에 기여했습니다.
또한, 수업 전에 진행되는 부담 없는 퀴즈는 학생들이 주제 학습에 집중하도록 의도를 설정하며, 수업 후 두 번째 퀴즈는 개념의 이해도를 더욱 높여줍니다. 이 커리큘럼은 유연하고 재미있게 설계되었으며 전체 또는 일부를 수강할 수 있습니다. 프로젝트는 작게 시작하여 12주 과정이 끝날 때쯤 점점 복잡해집니다.
우리는 JavaScript 프레임워크를 소개하지 않고 웹 개발자로서 기본 기술을 익힌 후 프레임워크를 채택하는 데 집중하도록 의도적으로 설계했습니다. 이 커리큘럼을 완료한 후 다음 단계로 Node.js를 배우는 것이 좋습니다. "Node.js 초보자 시리즈" 비디오 컬렉션을 통해 학습할 수 있습니다.
🧭 오프라인 접근
Docsify를 사용하여 이 문서를 오프라인에서 실행할 수 있습니다. 이 저장소를 포크하고, 로컬 머신에 Docsify 설치를 완료한 후, 이 저장소의 루트 폴더에서 docsify serve를 입력하세요. 웹사이트는 localhost의 포트 3000에서 제공됩니다: localhost:3000.
모든 강의의 PDF는 여기에서 찾을 수 있습니다.
🎒 기타 강의
우리 팀은 다른 강의도 제작합니다! 확인해보세요:
- 초보자를 위한 생성형 AI
- 초보자를 위한 생성형 AI .NET
- JavaScript로 생성형 AI
- Java로 생성형 AI
- 초보자를 위한 AI
- 초보자를 위한 데이터 과학
- 초보자를 위한 머신러닝
- 초보자를 위한 사이버 보안
- 초보자를 위한 웹 개발
- 초보자를 위한 IoT
- 초보자를 위한 XR 개발
- GitHub Copilot을 활용한 에이전트적 사용 마스터하기
- C#/.NET 개발자를 위한 GitHub Copilot 마스터하기
- 자신만의 Copilot 모험 선택하기
도움 받기
AI 앱을 개발하다가 막히거나 질문이 생기면 다음 커뮤니티에 참여하세요:
제품 피드백을 제공하거나 개발 중 오류가 발생한 경우 다음을 방문하세요:
라이선스
이 저장소는 MIT 라이선스에 따라 제공됩니다. 자세한 내용은 LICENSE 파일을 참조하세요.
면책 조항:
이 문서는 AI 번역 서비스 Co-op Translator를 사용하여 번역되었습니다. 정확성을 위해 최선을 다하고 있으나, 자동 번역에는 오류나 부정확성이 포함될 수 있습니다. 원본 문서의 원어 버전을 권위 있는 자료로 간주해야 합니다. 중요한 정보의 경우, 전문적인 인간 번역을 권장합니다. 이 번역 사용으로 인해 발생하는 오해나 잘못된 해석에 대해 당사는 책임을 지지 않습니다.


