From a07f6253bd56cddebaa3e1e734c97523468988d9 Mon Sep 17 00:00:00 2001 From: Noah Yang Date: Sun, 24 Feb 2019 20:51:04 +0900 Subject: [PATCH 01/18] Finish until `before-we-start-the-tutorial` --- content/tutorial/nav.yml | 8 +++---- content/tutorial/tutorial.md | 42 ++++++++++++++++++------------------ 2 files changed, 25 insertions(+), 25 deletions(-) diff --git a/content/tutorial/nav.yml b/content/tutorial/nav.yml index 8d498ab14..1a601bce9 100644 --- a/content/tutorial/nav.yml +++ b/content/tutorial/nav.yml @@ -1,16 +1,16 @@ -- title: Tutorial +- title: 자습서 items: - id: before-we-start-the-tutorial - title: Before We Start the Tutorial + title: 자습서를 시작하기 전에 href: /tutorial/tutorial.html#before-we-start-the-tutorial forceInternal: true subitems: - id: what-are-we-building - title: What Are We Building? + title: 무엇을 구현하나요? href: /tutorial/tutorial.html#what-are-we-building forceInternal: true - id: prerequisites - title: Prerequisites + title: 사전 준비 href: /tutorial/tutorial.html#prerequisites forceInternal: true - id: setup-for-the-tutorial diff --git a/content/tutorial/tutorial.md b/content/tutorial/tutorial.md index 9e1e58872..43224d870 100644 --- a/content/tutorial/tutorial.md +++ b/content/tutorial/tutorial.md @@ -1,6 +1,6 @@ --- id: tutorial -title: "Tutorial: Intro to React" +title: "자습서: React 시작하기" layout: tutorial sectionid: tutorial permalink: tutorial/tutorial.html @@ -12,42 +12,42 @@ redirect_from: - "docs/tutorial-zh-CN.html" --- -This tutorial doesn't assume any existing React knowledge. +이 자습서는 React에 대한 어떤 지식도 가정하지 않습니다. -## Before We Start the Tutorial {#before-we-start-the-tutorial} +## 자습서를 시작하기 전에 {#before-we-start-the-tutorial} -We will build a small game during this tutorial. **You might be tempted to skip it because you're not building games -- but give it a chance.** The techniques you'll learn in the tutorial are fundamental to building any React apps, and mastering it will give you a deep understanding of React. +우리는 자습서에서 작은 게임을 만들 것입니다. **게임을 만드고 싶지 않기 때문에 자습서를 건너뛰고 싶을 수 있습니다 -- 그래도 기회를 주세요.** 자습서에서 배우는 기술은 React 앱을 만드는 데 있어 기본이며 그것을 마스터하면 React에 대해 깊이 이해할 수 있습니다. ->Tip +> 팁 > ->This tutorial is designed for people who prefer to **learn by doing**. If you prefer learning concepts from the ground up, check out our [step-by-step guide](/docs/hello-world.html). You might find this tutorial and the guide complementary to each other. +> 자습서는 **실습을 통해 배우기**를 선호하는 사람들에 맞춰 설계 되었습니다. 기초부터 개념을 학습하길 선호한다면 [단계별 가이드](/docs/hello-world.html)를 확인해보세요. 자습서와 단계별 가이드는 상호 보완적입니다. -The tutorial is divided into several sections: +자습서는 아래와 같이 몇 가지 구역으로 나뉩니다. -* [Setup for the Tutorial](#setup-for-the-tutorial) will give you **a starting point** to follow the tutorial. -* [Overview](#overview) will teach you **the fundamentals** of React: components, props, and state. -* [Completing the Game](#completing-the-game) will teach you **the most common techniques** in React development. -* [Adding Time Travel](#adding-time-travel) will give you **a deeper insight** into the unique strengths of React. +* [자습서 설정](#setup-for-the-tutorial)은 자습서를 따를 수 있는 **시작점**을 안내합니다. +* [개요](#overview)는 React의 **기본**(components, props, state)을 알려줍니다. +* [게임 완성하기](#completing-the-game)는 React 개발에서 사용하는 **가장 일반적인 기술**을 가르쳐 줄 것입니다. +* [시간여행 추가하기](#adding-time-travel)는 React의 고유한 강점에 대한 **깊은 통찰력**을 줄 것입니다. -You don't have to complete all of the sections at once to get the value out of this tutorial. Try to get as far as you can -- even if it's one or two sections. +자습서를 익히기 위해 모든 부분을 한 번에 완료할 필요는 없습니다. 한 두 구역이라도 가능한 한 많이 시도 해보세요. -It's fine to copy and paste code as you're following along the tutorial, but we recommend to type it by hand. This will help you develop a muscle memory and a stronger understanding. +이 자습서를 따라하기 위해 코드를 복사하여 붙여넣는 것도 괜찮지만 직접 코드를 따라 적기를 추천합니다. 이 방식은 몸으로 기억하는 것과 더 강한 이해에 도움을 줄 것입니다. -### What Are We Building? {#what-are-we-building} +### 무엇을 구현하나요? {#what-are-we-building} -In this tutorial, we'll show how to build an interactive tic-tac-toe game with React. +우리는 React로 대화형 틱택토 게임을 만드는 방법을 알려드릴 것입니다. -You can see what we'll be building here: **[Final Result](https://codepen.io/gaearon/pen/gWWZgR?editors=0010)**. If the code doesn't make sense to you, or if you are unfamiliar with the code's syntax, don't worry! The goal of this tutorial is to help you understand React and its syntax. +최종 결과물은 **[이 페이지](https://codepen.io/gaearon/pen/gWWZgR?editors=0010)**에서 확인할 수 있습니다. 코드가 이해가 되지 않거나 코드의 문법에 익숙하지 않더라도 걱정마세요! 자습서의 목적은 React와 React 문법에 대한 이해를 돕는 것입니다. -We recommend that you check out the tic-tac-toe game before continuing with the tutorial. One of the features that you'll notice is that there is a numbered list to the right of the game's board. This list gives you a history of all of the moves that have occurred in the game, and is updated as the game progresses. +자습서를 진행하기 전에 틱택토 게임을 체험해보길 추천합니다. 주목할만한 특징 중 하나는 게임판 오른쪽에 번호가 매겨진 목록이 있다는 것입니다. 목록은 게임에서 일어난 모든 이동의 기록을 보여주며 게임을 진행하면 업데이트 됩니다. -You can close the tic-tac-toe game once you're familiar with it. We'll be starting from a simpler template in this tutorial. Our next step is to set you up so that you can start building the game. +틱택토 게임에 익숙해졌다면 종료해도 괜찮습니다. 우리는 자습서의 간단한 템플릿에서 시작할 것입니다. 다음 단계에서는 게임 구현을 시작하기 위한 설정을 다룹니다. -### Prerequisites {#prerequisites} +### 사전 준비 {#prerequisites} -We'll assume that you have some familiarity with HTML and JavaScript, but you should be able to follow along even if you're coming from a different programming language. We'll also assume that you're familiar with programming concepts like functions, objects, arrays, and to a lesser extent, classes. +당신이 HTML과 JavaScript에 어느정도 익숙하다고 가정하지만 다른 프로그래밍 언어를 사용하더라도 자습서를 따라갈 수 있습니다. 또한 함수, 객체, 배열, 가능하다면 클래스 같은 프로그래밍 개념에 익숙하다고 가정합니다. -If you need to review JavaScript, we recommend reading [this guide](https://developer.mozilla.org/en-US/docs/Web/JavaScript/A_re-introduction_to_JavaScript). Note that we're also using some features from ES6 -- a recent version of JavaScript. In this tutorial, we're using [arrow functions](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions), [classes](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes), [`let`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let), and [`const`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const) statements. You can use the [Babel REPL](babel://es5-syntax-example) to check what ES6 code compiles to. +JavaScript를 다시 보고싶다면 [이 가이드](https://developer.mozilla.org/en-US/docs/Web/JavaScript/A_re-introduction_to_JavaScript)를 추천합니다. JavaScript의 최신 버전인 ES6의 몇 가지 기능을 사용한다는 사실에 주목해주세요. 자습서에서는 [화살표 함수](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions), [클래스](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes), [`let`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let), [`const`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const)를 사용합니다. [Babel REPL](babel://es5-syntax-example)을 사용하여 ES6 코드가 어떻게 컴파일되는지 확인할 수 있습니다. ## Setup for the Tutorial {#setup-for-the-tutorial} From 5fb015f64a3723e8870b2c81f1cd1e6facc898c1 Mon Sep 17 00:00:00 2001 From: Noah Yang Date: Sat, 2 Mar 2019 18:53:14 +0900 Subject: [PATCH 02/18] Finish until setup-for-tutorial --- content/tutorial/nav.yml | 8 +++--- content/tutorial/tutorial.md | 50 ++++++++++++++++++------------------ 2 files changed, 29 insertions(+), 29 deletions(-) diff --git a/content/tutorial/nav.yml b/content/tutorial/nav.yml index 1a601bce9..3e7e0a370 100644 --- a/content/tutorial/nav.yml +++ b/content/tutorial/nav.yml @@ -14,20 +14,20 @@ href: /tutorial/tutorial.html#prerequisites forceInternal: true - id: setup-for-the-tutorial - title: Setup for the Tutorial + title: 자습서 설정 href: /tutorial/tutorial.html#setup-for-the-tutorial forceInternal: true subitems: - id: setup-option-1-write-code-in-the-browser - title: "Option 1: Write Code in the Browser" + title: "옵션 1: 브라우저에 코드 작성하기" href: /tutorial/tutorial.html#setup-option-1-write-code-in-the-browser forceInternal: true - id: setup-option-2-local-development-environment - title: "Option 2: Local Development Environment" + title: "옵션 2: 로컬 개발 환경" href: /tutorial/tutorial.html#setup-option-2-local-development-environment forceInternal: true - id: help-im-stuck - title: Help, I'm Stuck! + title: 도와주세요, 막히는 부분이 있어요! href: /tutorial/tutorial.html#help-im-stuck forceInternal: true - id: overview diff --git a/content/tutorial/tutorial.md b/content/tutorial/tutorial.md index 43224d870..be322f032 100644 --- a/content/tutorial/tutorial.md +++ b/content/tutorial/tutorial.md @@ -49,62 +49,62 @@ redirect_from: JavaScript를 다시 보고싶다면 [이 가이드](https://developer.mozilla.org/en-US/docs/Web/JavaScript/A_re-introduction_to_JavaScript)를 추천합니다. JavaScript의 최신 버전인 ES6의 몇 가지 기능을 사용한다는 사실에 주목해주세요. 자습서에서는 [화살표 함수](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions), [클래스](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes), [`let`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let), [`const`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const)를 사용합니다. [Babel REPL](babel://es5-syntax-example)을 사용하여 ES6 코드가 어떻게 컴파일되는지 확인할 수 있습니다. -## Setup for the Tutorial {#setup-for-the-tutorial} +## 자습서 설정 {#setup-for-the-tutorial} -There are two ways to complete this tutorial: you can either write the code in your browser, or you can set up a local development environment on your computer. +자습서를 완성하는 방법에는 두 가지가 있습니다. 브라우저에서 코드를 작성해도 되고 컴퓨터에 로컬 개발 환경을 설정해도 됩니다. -### Setup Option 1: Write Code in the Browser {#setup-option-1-write-code-in-the-browser} +### 설정 옵션 1: 브라우저에 코드 작성하기 {#setup-option-1-write-code-in-the-browser} -This is the quickest way to get started! +이 옵션은 가장 빠르게 시작하는 방식입니다! -First, open this **[Starter Code](https://codepen.io/gaearon/pen/oWWQNa?editors=0010)** in a new tab. The new tab should display an empty tic-tac-toe game board and React code. We will be editing the React code in this tutorial. +먼저 새 탭에서 **[시작 코드](https://codepen.io/gaearon/pen/oWWQNa?editors=0010)**를 열어주세요. 새 탭은 비어있는 틱택토 게임판과 React 코드를 보여줄 것입니다. 우리는 자습서에서 React 코드를 편집할 것입니다. -You can now skip the second setup option, and go to the [Overview](#overview) section to get an overview of React. +이제 두 번째 설정 옵션을 건너뛰고 [개요](#overview) 단락으로 넘어가서 React에 대한 개요를 확인해주세요. -### Setup Option 2: Local Development Environment {#setup-option-2-local-development-environment} +### 설정 옵션 2: 로컬 개발 환경 {#setup-option-2-local-development-environment} -This is completely optional and not required for this tutorial! +이 방식은 완전히 선택사항이며 이 자습서에 반드시 필요한 것은 아닙니다!
-Optional: Instructions for following along locally using your preferred text editor +선택 사항: 선호하는 텍스트 편집기를 사용하기 위한 지침 -This setup requires more work but allows you to complete the tutorial using an editor of your choice. Here are the steps to follow: +이 설정은 더 많은 작업을 요구하지만 당신이 선택한 편집기를 사용하여 자습서를 완성할 수 있게 합니다. 아래의 단계를 따라주세요. -1. Make sure you have a recent version of [Node.js](https://nodejs.org/en/) installed. -2. Follow the [installation instructions for Create React App](/docs/create-a-new-react-app.html#create-react-app) to make a new project. +1. 최신 버전의 [Node.js](https://nodejs.org/en/)가 설치되어 있는지 확인해주세요. +2. [Create React App 설치 지침](/docs/create-a-new-react-app.html#create-react-app)을 따라 새로운 프로젝트를 생성해주세요. ```bash npx create-react-app my-app ``` -3. Delete all files in the `src/` folder of the new project +3. 새로운 프로젝트의 `src/` 폴더에 있는 모든 파일을 삭제해주세요. -> Note: +> 주의 > ->**Don't delete the entire `src` folder, just the original source files inside it.** We'll replace the default source files with examples for this project in the next step. +> **`src` 폴더 전체가 아니라 폴더 내부의 기존 소스 파일들만 삭제 해주세요.** 다음 단계에서 기본 소스 파일을 이 프로젝트의 예제로 바꿀 것입니다. ```bash cd my-app cd src -# If you're using a Mac or Linux: +# Mac 또는 Linux 사용자의 경우 rm -f * -# Or, if you're on Windows: +# Windows 사용자 del * -# Then, switch back to the project folder +# 다시 프로젝트 폴더로 돌아가세요. cd .. ``` -4. Add a file named `index.css` in the `src/` folder with [this CSS code](https://codepen.io/gaearon/pen/oWWQNa?editors=0100). +4. `src/` 폴더에 `index.css`라는 파일을 생성하고 [이 CSS 코드](https://codepen.io/gaearon/pen/oWWQNa?editors=0100)를 추가해주세요. -5. Add a file named `index.js` in the `src/` folder with [this JS code](https://codepen.io/gaearon/pen/oWWQNa?editors=0010). +5. `src/` 폴더에 `index.js`라는 파일을 생성하고 [이 JS 코드](https://codepen.io/gaearon/pen/oWWQNa?editors=0010)를 추가해주세요. -6. Add these three lines to the top of `index.js` in the `src/` folder: +6. 위에서 생성한 `index.js`의 상단에 아래 세 줄을 추가해주세요. ```js import React from 'react'; @@ -112,15 +112,15 @@ import ReactDOM from 'react-dom'; import './index.css'; ``` -Now if you run `npm start` in the project folder and open `http://localhost:3000` in the browser, you should see an empty tic-tac-toe field. +이제 프로젝트 폴더에서 `npm start` 명령어를 실행하고 브라우저에서 `http://localhost:3000`를 열면 비어있는 틱택토 필드를 확인할 수 있습니다. -We recommend following [these instructions](https://babeljs.io/docs/editors/) to configure syntax highlighting for your editor. +에디터에서 구문 강조 표시를 설정하기 위해 [이 지침](https://babeljs.io/docs/editors/)을 따르길 권장합니다.
-### Help, I'm Stuck! {#help-im-stuck} +### 도와주세요, 막히는 부분이 있어요! {#help-im-stuck} -If you get stuck, check out the [community support resources](/community/support.html). In particular, [Reactiflux Chat](https://discord.gg/0ZcbPKXt5bZjGY5n) is a great way to get help quickly. If you don't receive an answer, or if you remain stuck, please file an issue, and we'll help you out. +막히는 부분이 생겼다면 [커뮤니티에서 지원하는 자료](/community/support.html)를 확인해보세요. 특히 [Reactiflux Chat](https://discord.gg/0ZcbPKXt5bZjGY5n)은 빠르게 도움을 받을 수 있는 좋은 방법입니다. 원하는 답을 얻지 못하거나 계속 막힌 상태라면 이슈를 제출해주세요. 우리가 도와드리겠습니다. ## Overview {#overview} From 716d7a35cef6250fffea6e64d908da3dadbbf1a0 Mon Sep 17 00:00:00 2001 From: Noah Yang Date: Sun, 10 Mar 2019 14:09:27 +0900 Subject: [PATCH 03/18] Ongoing making-an-interactive-component --- content/tutorial/tutorial.md | 54 ++++++++++++++++++------------------ 1 file changed, 27 insertions(+), 27 deletions(-) diff --git a/content/tutorial/tutorial.md b/content/tutorial/tutorial.md index 3ce8cb946..5fce4c1d5 100644 --- a/content/tutorial/tutorial.md +++ b/content/tutorial/tutorial.md @@ -192,11 +192,11 @@ Square 컴포넌트는 `