250x250
Rainbow๐ŸŒˆCoder
My dev Note๐Ÿ“’
Rainbow๐ŸŒˆCoder
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (411)
    • ๊ณต์ง€์‚ฌํ•ญ (0)
    • Debugger (10)
      • Visual Studio Debugger (1)
      • Chrome DevTools (3)
      • Visual Studio Code Debugger (4)
      • eclipse (1)
      • intelliJ (1)
    • OOP (2)
      • OOP (2)
    • TypeScript (54)
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript (54)
    • Javascript (87)
      • Javascript (45)
      • Node.js (19)
      • React (5)
      • FE ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ • (3)
      • React์™€ Node ๊ฐ™์ด ๋•Œ๋ ค์žก๊ธฐ (6)
      • next.js (2)
      • pixi.js (7)
    • ๋งˆํฌ์—… (23)
      • Html & Css (23)
    • C# (80)
      • C# (12)
      • ์ด๊ฒƒ์ด C#์ด๋‹ค (68)
    • C++ (30)
      • c++ (27)
      • win api (3)
    • Unity (18)
      • Unity(๊ธฐ์ดˆ) (8)
      • Unity(C#์ค‘๊ธ‰) (5)
      • ์œ ๋‹ˆํ‹ฐ ํฌํ†ค(๋„คํŠธ์›Œํฌ) (4)
      • unity c# MyCode (1)
    • Java & Spring (29)
      • Java (11)
      • ์Šคํ”„๋ง (8)
      • Java Algorithm (9)
      • Javs Data Structures (1)
    • ์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (15)
      • ์ž๋ฃŒ๊ตฌ์กฐ (5)
      • ์•Œ๊ณ ๋ฆฌ์ฆ˜ (10)
    • ํ˜•์ƒ๊ด€๋ฆฌ (15)
      • Git (11)
      • ์†Œ์ŠคํŠธ๋ฆฌ (3)
    • ๊ทธ๋ž˜ํ”ฝ์Šค (7)
      • WebGl (7)
    • AWS (3)
      • aws (3)
    • ๋ฆฌ๋ˆ…์Šค (5)
      • ๋ฆฌ๋ˆ…์Šค (5)
    • ์ฑ… ๋ฆฌ๋ทฐ (13)
      • ํด๋ฆฐ์ฝ”๋“œ(์ฑ…๋ฆฌ๋ทฐ) (3)
      • ์œ ์ง€๋ณด์ˆ˜๊ฐ€๋Šฅํ•œ์ฝ”๋”ฉ์˜๊ธฐ์ˆ C#ํŽธ(์ฑ…๋ฆฌ๋ทฐ) (1)
      • ๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ) (9)
    • Server (2)
      • ๊ฒŒ์ž„ ์„œ๋ฒ„(๋„คํŠธ์›Œํฌ, ๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ,OS) (2)
    • ์„ค๊ณ„, ์•„ํ‚คํ…์ณ (4)
    • ํŒŒ์ด์ฌ (5)
    • ๋””์ž์ธํŒจํ„ด (2)
    • mocha (2)
    • Jest (1)
    • Spine (1)
    • ์ธ๊ณต์ง€๋Šฅ (1)
      • ํ˜ผ์ž๊ณต๋ถ€ํ•˜๋Š”๋จธ์‹ ๋Ÿฌ๋‹+๋”ฅ๋Ÿฌ๋‹ (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ์ปดํฌ์ง€์…˜
  • ์œ„์ž„
  • MySQL
  • ใ…ฃใ„ท

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
Rainbow๐ŸŒˆCoder

My dev Note๐Ÿ“’

TypeScript/ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ๊ณจ๋ฑ…์ด @ ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ

2022. 5. 23. 18:46
728x90

https://m.blog.naver.com/pjt3591oo/222120496022

 

[typescript] ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ 1ํŽธ - ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ 4๊ฐ€์ง€ ๊ธฐ๋ณธ๊ตฌ์กฐ ์•Œ์•„๋ณด๊ธฐ

์•ˆ๋…•ํ•˜์„ธ์š”. ๋ฉ๊ฐœ์ž…๋‹ˆ๋‹ค ์ด๋ฒˆ๊ธ€์—์„œ๋Š” ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ์—์„œ ์ง€์›ํ•˜๋Š” ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ์˜ ๊ธฐ๋ณธ๊ตฌ์กฐ๋ฅผ ์•Œ์•„๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค...

blog.naver.com

https://sleepybird.tistory.com/158

 

[199์ผ์ฐจ]ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ

Reference ๐Ÿ—‚๊ณต์‹๋ฌธ์„œ ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ ๋„ค์ŠคํŠธ๋‚˜ ์•ต๊ทค๋Ÿฌ๊ฐ™์€ ํ”„๋ ˆ์ž„์›Œํฌ๋ฅผ ๋งˆ์ฃผํ•˜๋‹ค๋ณด๋ฉด ์‹ฌ์‹ฌ์น˜์•Š๊ฒŒ ๋ณผ์ˆ˜์žˆ๋Š”๋…€์„์ด ์žˆ๋‹ค. ๋ฐ”๋กœ ์ด ๊ณจ๋ฑ…์ด๊ฐ€ ๋ถ™์–ด์ง„ '๋ฐ์ฝ”๋ ˆ์ดํ„ฐ' ๋ผ๊ณ  ๋ถˆ๋ฆฌ๋Š” ๋…€์„์ด๋‹ค

sleepybird.tistory.com

๊ณจ๋ฑ…์ด๊ฐ€ ๋ถ™์–ด์ง„ '๋ฐ์ฝ”๋ ˆ์ดํ„ฐ' ๋ผ๊ณ  ๋ถˆ๋ฆฌ๋Š” ๋…€์„
ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ์—๋งŒ ์žˆ๋Š”๊ฑด ์•„๋‹ˆ๊ณ , ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ์—๋„ ์žˆ๋Š” ๊ธฐ๋Šฅ์ด์ง€๋งŒ ์ •์‹๊ธฐ๋Šฅ์ด์•„๋‹Œ,
ํ‘œ์ค€ํ™” ์ ˆ์ฐจ๋ฅผ ์ง„ํ–‰์ค‘์ธ ๊ธฐ๋Šฅ
ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ์—์„  ์ด ๊ธฐ๋Šฅ์„ ์ œ๊ณต์„ ํ•˜๊ณ , ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœํ•˜๋Š” ํ”„๋ ˆ์ž„์›Œํฌ์—์„œ๋„
์ด ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉ.

 

๋ฐ์ฝ”๋ ˆ์ดํ„ฐ๋Š” ํด๋ž˜์Šค, ์†์„ฑ, ๋ฉ”์†Œ๋“œ, ๋งค๊ฐœ๋ณ€์ˆ˜ ์•ž์— ๋ถ™์ผ ์ˆ˜ ์žˆ๋Š” ํ•จ์ˆ˜์ด๋‹ค.

 

https://youtu.be/clsMXU1tm-g

์˜ˆ์ œ1

function hello(constructFn: Function) {
	console.log(constructFn);
}

@hello
class Person {

}

 

์ถœ๋ ฅ

class Person {
}

 

 

์˜ˆ์ œ2

function hello(constructFn: Function) {
	console.log(constructFn);
	console.log('Hi!');
}

function bye(constructFn: Function) {
	console.log(constructFn);
	console.log('bye!');
}

function helloFactory(show: boolean) {
	if (show) {
		return hello;
	} else {
		return bye;
	}
}

@helloFactory(true)
class Person {
}

์ถœ๋ ฅ

class Person {
}
Hi!

 

 

 

์˜ˆ์ œ3

function hello(constructFn: Function) {
	console.log(constructFn);
	console.log('Hi!');
}

function bye(constructFn: Function) {
	console.log(constructFn);
	console.log('bye!');
}

function helloFactory(show: boolean) {
	if (show) {
		return hello;
	} else {
		return bye;
	}
}

@helloFactory(false)
class Person {
}

์ถœ๋ ฅ

class Person {
}
bye!

728x90

'TypeScript > ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ์˜ˆ์ œ] ์ •๊ทœ ํ‘œํ˜„์‹ regex, ์œ ํŠœ๋ธŒ์—์„œ id๊ฐ’๋งŒ ์ถ”์ถœํ•ด์„œ EMBED ํ•ด๋ณด๊ธฐ  (0) 2022.05.21
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] declare namespace  (0) 2022.05.06
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์œ ์šฉํ•œ ์ต์Šคํ…์…˜, Auto import  (0) 2022.05.05
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] .d.ts ์— ๋Œ€ํ•œ ์ดํ•ด  (0) 2022.05.04
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ! Non-null assertion operator  (0) 2022.05.02
    'TypeScript/ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ์˜ˆ์ œ] ์ •๊ทœ ํ‘œํ˜„์‹ regex, ์œ ํŠœ๋ธŒ์—์„œ id๊ฐ’๋งŒ ์ถ”์ถœํ•ด์„œ EMBED ํ•ด๋ณด๊ธฐ
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] declare namespace
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์œ ์šฉํ•œ ์ต์Šคํ…์…˜, Auto import
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] .d.ts ์— ๋Œ€ํ•œ ์ดํ•ด
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”