Skip to content

Commit 8798a27

Browse files
authored
Handbook v2에 새롭게 추가된 문서 추가 (#110)
* lint fix * remove twoslash * lint fix
1 parent 8bbbb3f commit 8798a27

14 files changed

+2846
-39
lines changed

README.md

+1-15
Original file line numberDiff line numberDiff line change
@@ -19,20 +19,6 @@
1919

2020
그 밖에도 다양한 의견 및 피드백은 언제나 환영합니다:)
2121

22-
## 2020 오픈소스 컨트리뷰톤 멘티 모집 (2020.6.1 ~ 7.6)
23-
공개 SW 포탈에서 현재 오픈소스 프로젝트 관련해서 멘티를 모집하고 있습니다.
24-
오픈소스 프로젝트에 기여해 보고자 하는 마음이 있었지만 막상 도전하기 어려우셨다면 2020 오픈소스 컨트리뷰톤 참여를 추천드립니다 😄
25-
26-
[오픈소스 컨트리뷰톤이란?](https://www.oss.kr/contributhon)
27-
28-
<a href="https://www.oss.kr/contributhon_project/show/0c290a4d-e97d-4281-b5d3-4fbc1cc8b152"><img src="./assets/images/readme/oss-image.jpg" width="300"></a>
29-
30-
Github에 대해 아직 잘 모르시거나
31-
이제 개발을 시작하는 초보 개발자시거나
32-
TypeScript에 대해 공부를 하고 싶거나
33-
TypeScript Handbook에 대해 번역 리뷰를 하고 싶으신 분이 있다면
34-
강력하게 추천합니다! [신청하기](https://www.oss.kr/contributhon_project/show/0c290a4d-e97d-4281-b5d3-4fbc1cc8b152)
35-
3622
## 컨트리뷰터 목록 ✨
3723

3824
도움 주셔서 감사합니다. ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
@@ -43,7 +29,7 @@ TypeScript Handbook에 대해 번역 리뷰를 하고 싶으신 분이 있다면
4329
<table>
4430
<tr>
4531
<td align="center"><a href="https://github.com/yeonjuan/dev-blog"><img src="https://avatars3.githubusercontent.com/u/41323220?v=4" width="80px;" alt=""/><br /><sub><b>YeonJuan</b></sub></a><br /><a href="#translation-yeonjuan" title="Translation">🌍</a></td>
46-
<td align="center"><a href="https://github.com/Bumkeyy"><img src="https://avatars0.githubusercontent.com/u/16663226?v=4" width="80px;" alt=""/><br /><sub><b>Kibeom Kwon</b></sub></a><br /><a href="#translation-Bumkeyy" title="Translation">🌍</a></td>
32+
<td align="center"><a href="https://bumkeyy.gitbook.io/bumkeyy-code/"><img src="https://avatars0.githubusercontent.com/u/16663226?v=4" width="80px;" alt=""/><br /><sub><b>Kibeom Kwon</b></sub></a><br /><a href="#translation-Bumkeyy" title="Translation">🌍</a></td>
4733
<td align="center"><a href="https://guyeol.github.io"><img src="https://avatars3.githubusercontent.com/u/7357413?v=4" width="80px;" alt=""/><br /><sub><b>GuyeolJeong</b></sub></a><br /><a href="#translation-guyeol" title="Translation">🌍</a></td>
4834
<td align="center"><a href="https://github.com/dvlprsh"><img src="https://avatars1.githubusercontent.com/u/48552752?v=4" width="80px;" alt=""/><br /><sub><b>Seohee Park</b></sub></a><br /><a href="#translation-dvlprsh" title="Translation">🌍</a></td>
4935
<td align="center"><a href="https://devjang.github.io"><img src="https://avatars1.githubusercontent.com/u/23068523?v=4" width="80px;" alt=""/><br /><sub><b>poco.j</b></sub></a><br /><a href="#translation-devJang" title="Translation">🌍</a></td>

SUMMARY.md

+46-24
Original file line numberDiff line numberDiff line change
@@ -2,47 +2,66 @@
22

33
* [소개](README.md)
44

5-
## 튜토리얼
5+
## 시작하기
66

7+
* [TS for the New Programmer(en)](pages/tutorials/ts-for-the-new-programmer.md)
8+
* [TS for JS Programmers(en)](pages/tutorials/ts-for-js-programmers.md)
9+
* [TS for OOP Programmers(en)](pages/tutorials/ts-for-oopers.md)
10+
* [TS for Functional Programmers(en)](pages/tutorials/ts-for-functional-programmers.md)
711
* [5분 안에 보는 TypeScript](pages/tutorials/typescript-in-5-minutes.md)
8-
* [ASP.NET Core](pages/tutorials/asp.net-core.md)
9-
* [걸프](pages/tutorials/gulp.md)
10-
* [JavaScript에서 마이그레이션](pages/tutorials/migrating-from-javascript.md)
11-
* [리액트 & 웹팩](pages/tutorials/react-&-webpack.md)
1212

1313
## 핸드북
1414

15+
* [핸드북이란(en)](pages/the-handbook.md)
1516
* [기본 타입](pages/basic-types.md)
16-
* [변수 선언](pages/variable-declarations.md)
1717
* [인터페이스](pages/interfaces.md)
18-
* [클래스](pages/classes.md)
1918
* [함수](pages/functions.md)
20-
* [제네릭](pages/generics.md)
19+
* [리터럴 타입(en)](pages/literal-types.md)
20+
* [유니언과 교차 타입(en)](pages/unions-and-intersections.md)
21+
* [클래스](pages/classes.md)
2122
* [열거형](pages/enums.md)
22-
* [타입 추론](pages/type-inference.md)
23-
* [타입 호환성](pages/type-compatibility.md)
23+
* [제네릭](pages/generics.md)
24+
25+
## 핸드북 레퍼런스
26+
2427
* [고급 타입](pages/advanced-types.md)
25-
* [심볼](pages/symbols.md)
28+
* [선언 병합](pages/declaration-merging.md)
29+
* [데코레이터](pages/decorators.md)
30+
* [유틸리티 타입](pages/utility-types.md)
2631
* [이터레이터와 제네레이터](pages/iterators-and-generators.md)
32+
* [JSX](pages/jsx.md)
33+
* [믹스인](pages/mixins.md)
2734
* [모듈](pages/modules.md)
35+
* [모듈 해석](pages/module-resolution.md)
2836
* [네임스페이스](pages/namespaces.md)
2937
* [네임스페이스와 모듈](pages/namespaces-and-modules.md)
30-
* [모듈 해석](pages/module-resolution.md)
31-
* [선언 병합](pages/declaration-merging.md)
32-
* [JSX](pages/jsx.md)
33-
* [데코레이터](pages/decorators.md)
34-
* [믹스인](pages/mixins.md)
38+
* [심볼](pages/symbols.md)
3539
* [트리플-슬래시 지시자](pages/triple-slash-directives.md)
36-
* [JavaScript 파일 타입 검사](pages/type-checking-javaScript-files.md)
37-
* [유틸리티 타입](pages/utility-types.md)
40+
* [타입 호환성](pages/type-compatibility.md)
41+
* [타입 추론](pages/type-inference.md)
42+
* [타입스크립트와 DOM(en)](pages/tutorials/dom-manipulation.md)
43+
* [변수 선언](pages/variable-declarations.md)
44+
45+
## 튜토리얼
46+
47+
* [ASP.NET Core](pages/tutorials/asp.net-core.md)
48+
* [걸프](pages/tutorials/gulp.md)
49+
* [JavaScript에서 마이그레이션](pages/tutorials/migrating-from-javascript.md)
50+
* [TypeScript와 Babel 사용하기(en)](pages/tutorials/babel-with-typescript.md)
51+
* [리액트 & 웹팩](pages/tutorials/react-&-webpack.md)
52+
53+
## 릴리즈 노트
54+
55+
* [TypeScript 3.9](pages/release-notes/typescript-3.9.md)
56+
* [TypeScript 3.8](pages/release-notes/typescript-3.8.md)
3857

3958
## 선언 파일
4059

4160
* [소개](pages/declaration-files/introduction.md)
42-
* [Library Structures](pages/declaration-files/library-structures.md)
4361
* [By Example](pages/declaration-files/by-example.md)
4462
* [Do's and Don'ts](pages/declaration-files/dos-and-don-ts.md)
4563
* [Deep Dive](pages/declaration-files/deep-dive.md)
64+
* [Library Structures](pages/declaration-files/library-structures.md)
4665
* [Templates](pages/declaration-files/templates.md)
4766
* [global-modifying-module.d.ts](pages/declaration-files/templates/global-modifying-module.d.ts.md)
4867
* [global-plugin.d.ts](pages/declaration-files/templates/global-plugin.d.ts.md)
@@ -54,17 +73,20 @@
5473
* [Publishing](pages/declaration-files/publishing.md)
5574
* [Consumption](pages/declaration-files/consumption.md)
5675

76+
## 자바스크립트
77+
78+
* [JavaScript에 TypeScript 적용하기(en)](pages/intro-to-js-with-ts.md)
79+
* [JavaScript 파일 타입 검사](pages/type-checking-javaScript-files.md)
80+
* [JSDoc 레퍼런스(en)](pages/jsdoc-reference.md)
81+
* [.js 파일에서 d.ts 파일 만들기(en)](pages/declaration-files/creating-dts-files-from-js.md)
82+
5783
## 프로젝트 환경설정
5884

5985
* [tsconfig.json](pages/tsconfig.json.md)
6086
* [컴파일러 옵션](pages/compiler-options.md)
6187
* [프로젝트 레퍼런스](pages/project-references.md)
6288
* [MSBuild에서의 컴파일러 옵션](pages/compiler-options-in-msbuild.md)
6389
* [빌드 도구와 통합](pages/integrating-with-build-tools.md)
64-
* [Nightly 빌드](pages/nightly-builds.md)
6590
* [configuring-watch (en)](pages/configuring-watch.md)
91+
* [Nightly 빌드](pages/nightly-builds.md)
6692

67-
## 릴리즈 노트
68-
69-
* [TypeScript 3.9](pages/release-notes/typescript-3.9.md)
70-
* [TypeScript 3.8](pages/release-notes/typescript-3.8.md)
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,87 @@
1+
---
2+
title: Creating .d.ts Files from .js files
3+
layout: docs
4+
permalink: /docs/handbook/declaration-files/dts-from-js.html
5+
oneline: "How to add d.ts generation to JavaScript projects"
6+
---
7+
8+
[With TypeScript 3.7](/docs/handbook/release-notes/typescript-3-7.html#--declaration-and---allowjs),
9+
TypeScript added support for generating .d.ts files from JavaScript using JSDoc syntax.
10+
11+
This set up means you can own the editor experience of TypeScript-powered editors without porting your project to TypeScript, or having to maintain .d.ts files in your codebase.
12+
TypeScript supports most JSDoc tags, you can find [the reference here](/docs/handbook/type-checking-javascript-files.html#supported-jsdoc).
13+
14+
## Setting up your Project to emit .d.ts files
15+
16+
To add creation of .d.ts files in your project, you will need to do up-to four steps:
17+
18+
* Add TypeScript to your dev dependencies
19+
* Add a `tsconfig.json` to configure TypeScript
20+
* Run the TypeScript compiler to generate the corresponding d.ts files for JS files
21+
* (optional) Edit your package.json to reference the types
22+
23+
### Adding TypeScript
24+
25+
You can learn how to do this in our [installation page](/download).
26+
27+
### TSConfig
28+
29+
The TSConfig is a json5 file which configures both your compiler flags, and declare where to find files.
30+
In this case, you will want a file like the following:
31+
32+
```json5
33+
{
34+
// Change this to match your project
35+
include: ["src/**/*"],
36+
37+
compilerOptions: {
38+
// Tells TypeScript to read JS files, as
39+
// normally they are ignored as source files
40+
allowJs: true,
41+
// Generate d.ts files
42+
declaration: true,
43+
// This compiler run should
44+
// only output d.ts files
45+
emitDeclarationOnly: true,
46+
// Types should go into this directory.
47+
// Removing this would place the .d.ts files
48+
// next to the .js files
49+
outDir: "dist",
50+
},
51+
}
52+
```
53+
54+
You can learn more about the options in the [tsconfig reference](/reference).
55+
An alternative to using a TSConfig file is the CLI, this is the same behavior as a CLI command.
56+
57+
```sh
58+
npx typescript src/**/*.js --declaration --allowJs --emitDeclarationOnly --outDir types
59+
```
60+
61+
## Run the compiler
62+
63+
You can learn how to do this in our [installation page](/download).
64+
You want to make sure these files are included in your package if you have the files in your project's `.gitignore`.
65+
66+
## Editing the package.json
67+
68+
TypeScript replicates the node resolution for modules in a `package.json`, with an additional step for finding .d.ts files.
69+
Roughly, the resolution will first check the optional `"types"` field, then the `"main"` field, and finally will try `index.d.ts` in the root.
70+
71+
| Package.json | Location of default .d.ts |
72+
| :------------------------ | :----------------------------- |
73+
| No "types" field | checks "main", then index.d.ts |
74+
| "types": "main.d.ts" | main.d.ts |
75+
| "types": "./dist/main.js" | ./main/main.d.ts |
76+
77+
If absent, then "main" is used
78+
79+
| Package.json | Location of default .d.ts |
80+
| :----------------------- | :------------------------ |
81+
| No "main" field | index.d.ts |
82+
| "main":"index.js" | index.d.ts |
83+
| "main":"./dist/index.js" | ./dist/index.d.ts |
84+
85+
## Tips
86+
87+
If you'd like to write tests for your .d.ts files, try [tsd](https://github.com/SamVerschueren/tsd).

pages/intro-to-js-with-ts.md

+69
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
---
2+
title: JS Projects Utilizing TypeScript
3+
layout: docs
4+
permalink: /docs/handbook/intro-to-js-ts.html
5+
oneline: How to add type checking to JavaScript files using TypeScript
6+
---
7+
8+
The type system in TypeScript has different levels of strictness when working with a codebase:
9+
10+
* A type-system based only on inference with JavaScript code
11+
* Incremental typing in JavaScript [via JSDoc](/docs/handbook/jsdoc-supported-types.html)
12+
* Using `// @ts-check` in a JavaScript file
13+
* TypeScript code
14+
* TypeScript with [`strict`](/tsconfig#strict) enabled
15+
16+
Each step represents a move towards a safer type-system, but not every project needs that level of verification.
17+
18+
## TypeScript with JavaScript
19+
20+
This is when you use an editor which uses TypeScript to provide tooling like auto-complete, jump to symbol and refactoring tools like rename.
21+
The [homepage](/) has a list of editors which have TypeScript plugins.
22+
23+
## Providing Type Hints in JS via JSDoc
24+
25+
In a `.js` file, types can often be inferred. When types can't be inferred, they can be specified using JSDoc syntax.
26+
27+
JSDoc annotations come before a declaration will be used to set the type of that declaration. For example:
28+
29+
```js twoslash
30+
/** @type {number} */
31+
var x;
32+
33+
x = 0; // OK
34+
x = false; // OK?!
35+
```
36+
37+
You can find the full list of supported JSDoc patterns [in JSDoc Supported Types](/docs/handbook/jsdoc-supported-types.html).
38+
39+
## `@ts-check`
40+
41+
The last line of the previous code sample would raise an error in TypeScript, but it doesn't by default in a JS project.
42+
To enable errors in your JavaScript files add: `// @ts-check` to the first line in your `.js` files to have TypeScript raise it as an error.
43+
44+
```js twoslash
45+
// @ts-check
46+
// @errors: 2322
47+
/** @type {number} */
48+
var x;
49+
50+
x = 0; // OK
51+
x = false; // Not OK
52+
```
53+
54+
If you have a lot of JavaScript files you want to add errors to then you can switch to using a [`jsconfig.json`](/docs/handbook/tsconfig-json.html).
55+
You can skip checking some files by adding a `// @ts-nocheck` comment to files.
56+
57+
TypeScript may offer you errors which you disagree with, in those cases you can ignore errors on specific lines by adding `// @ts-ignore` or `// @ts-expect-error` on the preceding line.
58+
59+
```js twoslash
60+
// @ts-check
61+
/** @type {number} */
62+
var x;
63+
64+
x = 0; // OK
65+
// @ts-expect-error
66+
x = false; // Not OK
67+
```
68+
69+
To learn more about how JavaScript is interpreted by TypeScript read [How TS Type Checks JS](/docs/handbook/type-checking-javascript-files.html)

0 commit comments

Comments
 (0)