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. 4. 26. 15:59
728x90

์•„๋ž˜ ์Šคํƒ€์ผ๋“ค๋„ ์ œ๋„ค๋ฆญ ํƒ€์ž… ๋ณ„์นญ์ด๋‹ค.

//์ฝ๊ธฐ ์ „์šฉ ๋ฐฐ์—ด๊ณผ ํŠœํ”Œ ๋งŒ๋“œ๋Š” ์—ฌ๋Ÿฌ๊ฐ€์ง€ ์„ ์–ธ ๋ฐฉ๋ฒ•
type A = readonly string[];    //readonly string[]
type B = ReadonlyArray<string>;//readonly string[]
type C = Readonly<string[]>;   //readonly string[]
type D = readonly [number,string]; //readonly [number,string]
type E = Readonly<[number,string]>;//readonly [number,string]

 

๊ฐ„๋‹จํ•œ ์˜ˆ๋ฅผ ํ†ตํ•ด ํƒ€์ž… ๋ณ„์นญ์—์„œ ์ œ๋„ค๋ฆญ์„ ํ™œ์šฉํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ๋” ์ž์„ธํžˆ ์‚ดํŽด๋ณด์ž.

(์ฐธ๊ณ ๋กœ ์ด ์˜ˆ์ € ์ „์— ts์—์„œ DOM์„ ๋ถ€๋ฅด๊ธฐ ์œ„ํ•ด

tsconfig.json์˜ lib ์˜ต์…˜

ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๊ฐ€ ๋นŒ๋“œ ๋  ๋•Œ ์ฐธ์กฐํ•˜๋Š” tsconfig.json์˜ ์ปดํŒŒ์ผ ์˜ต์…˜์ค‘์— lib์ด๋ผ๋Š” ํ•ญ๋ชฉ์ด ์žˆ๋Š”๋ฐ, ์ตœ์†Œํ•œ ์•„๋ž˜ ์ŠคํŽ™์€ ๋งž์ถฐ์ฃผ์–ด์•ผํ•œ๋‹ค.

// tsconfig.json
//์ฐธ๊ณ  : https://norux.me/59
{
  "CompilerOptions": {
    "target": "es5",
    "module": "commonjs",
    "lib": [
      "dom",
      "es5"
    ]
  }
}

click์ด๋‚˜ mousedown ๊ฐ™์€ DOM ์ด๋ฒคํŠธ๋ฅผ ์„ค๋ช…ํ•˜๋Š” MyEvent ํƒ€์ž…์„ ์ •์˜

//ํƒ€์ž… ๋ณ„์น˜์—์„œ๋Š” ํƒ€์ž… ๋ณ„์นญ๋ช…๊ณผ ํ• ๋‹น๊ธฐํ˜ธ(=) ์‚ฌ์ด์—๋งŒ ์ œ๋„ค๋ฆญ ํƒ€์ž…์„ ์„ ์–ธํ•  ์ˆ˜ ์žˆ๋‹ค
type MyEvent<T> = {
  target: T;
  type: string;
};

MyEvent์˜ target ํ”„๋กœํผํ‹ฐ๋Š” <button />, <div /> ๋“ฑ ์ด๋ฒคํŠธ๊ฐ€ ๋ฐœ์ƒํ•œ ์š”์†Œ๋ฅผ ๊ฐ€๋ฆฌํ‚จ๋‹ค.

์˜ˆ๋ฅผ ๋“ค์–ด ๋ฒ„ํŠผ ์ด๋ฒคํŠธ๋Š” ๋‹ค์Œ์ฒ˜๋Ÿผ ํ‘œํ˜„ํ•  ์ˆ˜ ์žˆ๋‹ค.

type ButtonEvent = MyEvent<HTMLButtonElement>;

MyEvent ๊ฐ™์€ ์ œ๋„ค๋ฆญ ํƒ€์ž…์„ ์‚ฌ์šฉํ•  ๋•Œ๋Š” ํƒ€์ž…์ด ์ž๋™์œผ๋กœ ์ถ”๋ก ๋˜์ง€ ์•Š์œผ๋ฏ€๋กœ ํƒ€์ž… ๋งค๊ฐœ๋ณ€์ˆ˜๋ฅผ ๋ช…์‹œ์ ์„ ํ•œ์ •ํ•ด์•ผ ํ•œ๋‹ค.

let myEvent: MyEvent<HTMLButtonElement | null> = {
  target: document.querySelector("#myButton"),
  type: "click",
};

MyEvent๋กœ TimedEvent ๊ฐ™์€ ๋‹ค๋ฅธ ํƒ€์ž…์„ ๋งŒ๋“ค ์ˆ˜ ์žˆ๋‹ค. ์ด๋ ‡๊ฒŒ ์ •์˜ํ•˜๋ฉด ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” TimedEvent์˜ ์ œ๋„ค๋ฆญ T๋กœ ํ•œ์ •ํ•  ๋•Œ ์ด๋ฆ„ MyEvent์—๋„ ์ ์šฉํ•œ๋‹ค.

type TimedEvent<T> = {
  event: MyEvent<T>;
  from: Date;
  to: Date;
};

์ œ๋„ค๋ฆญ ํƒ€์ž… ๋ณ„์นญ์„ ํ•จ์ˆ˜ ์‹œ๊ทธ๋‹ˆ์ฒ˜์—๋„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ๊ตฌ์ฒด ํƒ€์ž… T๋กœ ํ•œ์ •ํ•˜๋ฉด์„œ ๋™์‹œ์— MyEvent์—๋„ ์ ์šฉํ•œ๋‹ค.

function triggerEvent<T>(event: MyEvent<T>): void {
  //...
}
triggerEvent({
  //T๋Š” Element|null
  target: document.querySelector("#myButton"),
  type: "mouseover",
});

์ด์ œ ์–ด๋–ค ์ผ์ด ์ผ์–ด๋‚˜๋ƒ๋ฉด...

1. ๊ฐ์ฒด์— triggerEvent๋ฅผ ํ˜ธ์ถœํ•œ๋‹ค

2. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ํ•จ์ˆ˜์˜ ์‹œ๊ทธ๋‹ˆ์ฒ˜ ์ •๋ณด๋ฅผ ์ด์šฉํ•ด ์ „๋‹ฌํ•œ ์ธ์ˆ˜๊ฐ€ MyEvent<T> ํƒ€์ž…์ด์–ด์•ผ ํ•จ์„ ํŒŒ์•…ํ•œ๋‹ค. ๋˜ํ•œ MyEvent<T>๋ฅผ

{target: T, type: string }์œผ๋กœ ์ •์˜ํ–ˆ๋‹ค๋Š” ์‚ฌ์‹ค๋„ ์ธ์ง€ํ•œ๋‹ค.

3. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ํ˜ธ์ถœ์ž๊ฐ€ ์ „๋‹ฌํ•œ ๊ฐ์ฒด์˜ target ํ•„๋“œ๊ฐ€ document.querySelector('#myButton')์ด๋ผ๋Š” ์‚ฌ์‹ค์„ ํŒŒ์•…ํ•œ๋‹ค. ์ฆ‰, T์˜ ํƒ€์ž…์€ document.querySelector('#myButton')์ด๋ฉฐ document.querySelector('#myButton')์€ Element | null ํƒ€์ž…์ด๋‹ค. ๋”ฐ๋ผ์„œ T๋Š” Element | null ํƒ€์ž…์œผ๋กœ ํ•œ์ •๋œ๋‹ค.

4. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ๋ชจ๋“  T๋ฅผ Element | null ๋กœ ๋Œ€์ฒดํ•œ๋‹ค.

5. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ๋ชจ๋“  ํƒ€์ž…์ด ํ• ๋‹น์„ฑ์„ ๋งŒ์กฑํ•˜๋Š”์ง€ ํ™•์ธํ•œ๋‹ค. ์ด๋ ‡๊ฒŒ ํƒ€์ž… ํ™•์ธ์ด ์ด๋ฃจ์–ด์ง„๋‹ค. 

 

 

์Œ... DOM ์—ฐ๋™์ด ์ž˜ ์•ˆ๋จ.

DOM ๋Šฅ์ˆ™ํ•ด์ง€๊ณ  ๋‹ค์‹œ ๋Œ์•„์™€์„œ ์‹œ๋„ํ•ด๋ด์•ผ๊ฒ ์Œ

์ถœ์ฒ˜ : ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ํ”„๋กœ๊ทธ๋ž˜๋ฐ(์ฑ…)

 

 

 

์ฐธ๊ณ  ๋ฌธํ—Œ : http://www.devdic.com/javascript/refer/grammar/document:2488/%EC%A0%84%EC%97%AD%EB%B3%80%EC%88%98%EB%A1%9C%EC%84%9C%EC%9D%98-DOM-%EC%B0%B8%EC%A1%B0

 

์ „์—ญ๋ณ€์ˆ˜๋กœ์„œ์˜ DOM ์ฐธ์กฐ::JavaScript ๋ ˆํผ๋Ÿฐ์Šค

Writing ์ „์—ญ๋ณ€์ˆ˜๋กœ์„œ์˜ DOM ์ฐธ์กฐ ๋“ค์–ด๊ฐ€๋ฉฐ Click me window.addEventListener("load", function() { myButton.onclick = () => alert("Clicked"); }); ์œ„์™€ ๊ฐ™์€ ์ฝ”๋“œ๊ฐ€ ์ •์ƒ ์ž‘๋™ํ• ๊นŒ? ๋†€๋ž๊ฒŒ๋„ ํฌ๋กฌ(Chrome), ํŒŒ์ด์–ดํญ์Šค(Firefox),

www.devdic.com

<!DOCTYPE html>
<html>
<head></head>
<body>
<button type="button" id="myButton">Click me</button>

<script type="text/javascript">
window.addEventListener("load", function() {
    myButton.onclick = () => alert("Clicked");
});
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<head></head>
<body>
<button type="button" id="myButton">Click me</button>

<script type="text/javascript">
window.addEventListener("load", function() {
    var myButton = document.querySelector("#myButton");
    myButton.onclick = () => alert("Clicked");
});
</script>
</body>
</html>

 

 

 

 

728x90

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

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ํ•œ์ •๋œ ๋‹คํ˜•์„ฑ, ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ํ”„๋กœ๊ทธ๋ž˜๋ฐ ์ด์ง„ํŠธ๋ฆฌ ์˜ˆ์ œ ๋ถ„์„  (0) 2022.04.26
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ํƒ€์ž…๋ณ„์นญ ์ธํ„ฐ์„น์…˜์— ์˜ํ•œ ํ™•์žฅ  (0) 2022.04.26
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ts(2584) 'document' ์ด๋ฆ„์„ ์ฐพ์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค. ๋Œ€์ƒ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ๋ณ€๊ฒฝํ•˜๋ ค๋Š” ๊ฒฝ์šฐ 'dom'์„ ํฌํ•จํ•˜๋„๋ก 'lib' ์ปดํŒŒ์ผ๋Ÿฌ ์˜ต์…˜์„ ๋ณ€๊ฒฝํ•ด ๋ณด์„ธ์š”.  (0) 2022.04.26
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ค๋ฆญ ํƒ€์ž… ๋ช…์‹œ ์ฃผ์˜์‚ฌํ•ญ  (0) 2022.04.26
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ๊ณตํ™ˆ] User-Defined Type Guards  (0) 2022.04.26
    'TypeScript/ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ํ•œ์ •๋œ ๋‹คํ˜•์„ฑ, ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ํ”„๋กœ๊ทธ๋ž˜๋ฐ ์ด์ง„ํŠธ๋ฆฌ ์˜ˆ์ œ ๋ถ„์„
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ํƒ€์ž…๋ณ„์นญ ์ธํ„ฐ์„น์…˜์— ์˜ํ•œ ํ™•์žฅ
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ts(2584) 'document' ์ด๋ฆ„์„ ์ฐพ์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค. ๋Œ€์ƒ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ๋ณ€๊ฒฝํ•˜๋ ค๋Š” ๊ฒฝ์šฐ 'dom'์„ ํฌํ•จํ•˜๋„๋ก 'lib' ์ปดํŒŒ์ผ๋Ÿฌ ์˜ต์…˜์„ ๋ณ€๊ฒฝํ•ด ๋ณด์„ธ์š”.
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ค๋ฆญ ํƒ€์ž… ๋ช…์‹œ ์ฃผ์˜์‚ฌํ•ญ
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

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