-
Notifications
You must be signed in to change notification settings - Fork 7
/
syntax-ts.ts
118 lines (81 loc) · 2.14 KB
/
syntax-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
// * ------------------------------------------------ Optional Chaining
{
const data = { bar: { baz: console.log } };
type validData = typeof data | null;
const foo: validData = Math.random() ? data : null;
const x = foo?.bar?.baz();
console.log('x is', x);
}
// * ---------------- alternative
{
const data = { bar: { baz: console.log } };
type validData = typeof data | null;
const foo: validData = Math.random() ? data : null;
const x =
foo === null || foo === undefined
? undefined
: foo.bar === null || foo.bar === undefined
? undefined
: foo.bar.baz();
console.log('x is', x);
}
// * ------------------------------------------------ Non-null assertion operator
{
interface Entity {
name: string;
}
const validOrThrow = (e) => {
if (!e) throw 'your value is empty';
};
const process = (e?: Entity) => {
validOrThrow(e);
const name = e!.name;
console.log(name);
};
process({ name: 'Mick' });
}
// * ---------------- alternative
{
interface Entity {
name: string;
}
const validOrThrow = (e) => {
if (!e) throw 'your value is empty';
};
const process = (e?: Entity) => {
validOrThrow(e);
const name = e !== undefined && e.name;
console.log(name);
};
process({ name: 'Mick' });
}
// * ------------------------------------------------ Nullish Coalescing
{
const foo = null;
const bar = () => 'John';
const x = foo ?? bar();
console.log('x is', x);
}
// * ---------------- alternative
{
const foo = null;
const bar = () => 'John';
const x = foo !== null && foo !== undefined ? foo : bar();
console.log('x is', x);
}
// * ------------------------------------------------ overload
{
function simpleAdd(a: number): (b: number) => number;
function simpleAdd(a: number, b: number): number;
function simpleAdd(a, b?) {
if (b === undefined) return (b) => a + b;
return a + b;
}
const result = simpleAdd(1, 2);
console.log(result);
const semiAdd = simpleAdd(3);
const result2 = semiAdd(4);
console.log(result2);
}
// * ------------------------------------------------ Pattern matching
// * not support