-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathTS.ts
199 lines (157 loc) · 5.03 KB
/
TS.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
// TYPESCRIPT - Strongly Typed JavaScript - by Beumsk
// npm install typescript
// npx tsc --init // init TS project
// change config in tsconfig.json
// npx tsc // compile TS
// npx tsc -w // watch TS changes to be compiled
// test Typescript live -> https://www.typescriptlang.org/play
// add in package.json scripts
// "ts": "node_modules/.bin/tsc --noEmit --skipLibCheck"
// TSCONFIG.JSON
{
"compilerOptions": {
"target": "commonjs", // also ES6...
"sourceMap": false,
"watch": true,
"lib": ["dom", "es2017"]
},
"include": ["src/**/*"],
"exclude": ["node_modules/**/*"]
}
// @ts-ignore -> ignore next line ts errors
// @ts-nocheck -> ignore file ts errors
// IMPLICIT TYPING
const num = 1;
const str = 'Hello';
const bool = false;
const arr = [];
const obj = {};
const func() {}
const func = () => {}
// EXPLICIT TYPING
const num: number = 1;
const str: string = 'Hello';
const bool: boolean = false;
let dualType: (string | number); dualType = 123; dualType = "ABC"; // both types work
let anyType: any; anyType = false; anyType = "any string"; // any type works
const arr: string[] = ['one', 'two', 'three'];
const arr: (string | number)[] = ['one', 2, 'three'];
const arr: any[] = ['one', 2, false];
const arr: Array<string> = ['one', 'two', 'three'];
const arr: [number, string] = [1, "two"];
const obj: {} = { title: "Hello", id: 1 };
const obj: { title: string; id: number } = { title: "Hello", id: 1 };
const obj: { title: string; id: number, online?: boolean } = { title: "Hello", id: 1 };
function func(): void { console.log('Hi!') } // void is only for function not returning any value
const func = (): void => console.log('Hi!');
function func(name: string, age: number): string { return 'Hi ' + name + ', you are ' + age } // you can specify type of each arg and the returned type as well
const func = (name: string, age: number): string => 'Hi ' + name + ', you are ' + age;
const some: any; // any type; you can use all types and all operations (some.thing)
const some: unknown; // unknown type; you can use all types but no operations without manual type checking
// TYPE ALIAS
type StrOrNum = string|number;
let dualType: StrOrNum; dualType = 123; dualType = '123';
// fixed values alias
type Themes = "light" | "dark" | "rose";
let theme: lightOrDark; theme = "light"; theme = "dark";
// excluding alias
type Themes = "light" | "dark" | "rose";
type duoThemes = Exclude<Themes, "rose">;
let excludedAlias: duoThemes = 'dark'; // not 'rose'
// func alias
type myFunc = (a:number, b:string) => void;
let write: myFunc = (num, str) => { console.log(num + " times " + str) };
// combining aliases
type X = { a: string, b: number };
type Y = X & { c: string, d: number };
let combinedAlias: Y = { a: 'a', b: 2, c: 'c', d: 4 };
// omitting alias
type X = { a: string, b: number, c: string, d: number };
type Y = Omit<X, 'd' | 'c'>;
let omitedAlias: Y = { a: 'a', b: 2 };
// smart alias
type Smart = { name: string } & ({ type: 'circle', radius: number } | { type: 'square', side: number });
let smartCircle: Smart = { name: 'c', type: 'circle', radius: 10 };
let smartSquare: Smart = { name: 's', type: 'square', side: 10 };
// INTERFACE
interface XX { a: string, b: number };
interface YY extends XX { c: string, d: number };
let combinedInterFace: YY = { a: 'a', b: 2, c: 'c', d: 4 };
interface ComplexObject {
title: string;
data: {
id: number;
name: string;
}[];
optionalData?: [];
twoTypes: string | number;
func: (param: string) => string;
[key: string]: any;
}
const obj: ComplexObject = {
title: 'Title',
data: [
{
id: 1,
name: 'data1'
},
{
id: 2,
name: 'data2'
}
],
twoTypes: 'dual',
func: (param) => 'string: ' + param,
anotherProp: true
}
// GENERICS
interface GenericInterface<T> { // or type
id: number;
title: string;
extra: T[];
}
const article: GenericInterface<string> = {
id: 1,
title: "first piece",
extra: ["str", "string"]
}
const article: GenericInterface<number> = {
id: 1,
title: "first piece",
extra: [2, 4]
}
interface GenericInterface2<T = boolean> { // or type
id: number;
title: string;
extra: T[];
}
const article: GenericInterface2 = {
id: 1,
title: "first piece",
extra: [true, false]
}
const article: GenericInterface2<number> = {
id: 1,
title: "first piece",
extra: [2, 4]
}
interface GenericInterface3<T extends object> { // or type
id: number;
title: string;
extra: T[];
}
const article: GenericInterface3<{id:number, name:string}> = {
id: 1,
title: "first piece",
extra: [{id:1, name:"author"}]
}
type Arr = { id: string, type: "new" | "old", name: string };
const arr = [{id:1, type:"new", name:"First"}];
function addToArray<T>(array: T[], item: T): T[] {
array.push(item);
return array;
}
addToArray(arr, {id:2, type:"new", name:"Second"}); // OK
addToArray<Arr>(arr, {id:3, type:"old", name:"Third"}); // OK
addToArray(arr, {id:4, type:"fake", name:"Fourth"}); // doesn't throw an error because of inferring
addToArray<Arr>(arr, {id:5, type:"fake", name:"Fifth"}); // throw error ebcause explicit