js47 JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (34)_ prototype (ํน์ง ๋ฐ constructor์์ ์ฐจ์ด) JS์ prototype์ ๋ํด์ ์์๋ณด์. 0. ์์(inheritance) ๊ฐ์ฒด์งํฅ์ ๊ฐ๋ ์ค ํ๋์ธ ์์์ ๊ฐ๋จํ ํํํ๋ฉด ๋ถ๋ชจ ๊ฐ์ฒด์ ์์ฑ์ ์์ ๊ฐ์ฒด๊ฐ ๋ฌผ๋ ค๋ฐ๋ ๊ฒ์ ๋งํ๋ค. JS์์ ์ด๊ฒ์ ๊ตฌํํ๊ธฐ ์ํ ๋ฐฉ๋ฒ์ด ๋ช๊ฐ์ง ์๋๋ฐ ์ฒซ๋ฒ์งธ๋ ์ ๋ฒ์๊ฐ์ ๋ค๋ฃจ์๋ constructor ๋ฌธ๋ฒ์ด๋ค. 2023.08.08 - [๐ | WEB DEV/Vanilla JS] - JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (33)_ constructor ๋ฌธ๋ฒ ๊ทธ๋ฆฌ๊ณ ๋๋ฒ์งธ ๋ฐฉ๋ฒ์ด prototype์ด๋ค. 1. prototype ๋ชจ๋ ์์ฑ์ ํจ์๋ค์ prototype์ ๋ด์ฅํ๊ณ ์๋ค. function Student(name, code){ this.name = name; this.code = code; } console.log(Student.prot.. 2023. 8. 11. JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (33)_ constructor ๋ฌธ๋ฒ JS์ Object๋ฅผ ์์ฑํ๋ constructor ๋ฌธ๋ฒ์ ๋ํด์ ์์๋ณด์. 0. Object์ ๋ณต์ฌ ๋ฌธ์ Object๋ Reference ๋ฐ์ดํฐ ํ์ ์ด๋ค. ๋ฐ๋ผ์ ๋ณต์ฌ๋ฅผ ํ ๋ ์๋์ ๊ฐ์ด ๋จ์ํ๊ฒ ์งํํด์๋ ์๋๋ค. ์๋ชป๋ ๊ฐ์ฒด ๋ณต์ฌ ์์ let obj1 = {name: "Kassid"}; let obj2 = obj1; ์ด๋ ๊ฒ ๋ณต์ฌ๋ฅผ ํ๊ฒ ๋๋ค๋ฉด ๊ฐ ์์ฒด์ ๋ณต์ฌ๊ฐ ์๋ ๋ ํผ๋ฐ์ค๋ฅผ ๋ณต์ฌํ๋ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ ์์ ํ ๋ณต์ฌ๋ผ๊ณ ํ ์ ์๋ค. 1. constructor ๋ฌธ๋ฒ constructor๋ ์์ object๋ฅผ ์์ฑ๊ธฐ๊ณ๋ผ๊ณ ํ ์ ์๋ค. ์ด๋ฅผ ์ด์ฉํด ์์ ๋ณต์ฌ๋ฌธ์ ๋ฅผ ํด๊ฒฐํ ์ ์๋ค. ์ด๋ฅผ ์ด์ฉํด์ ๋น์ทํ ๊ฐ์ฒด๋ฅผ ์์ฝ๊ฒ ์์ฐํด๋ผ ์ ์๋ค. ์ฌ์ฉ๋ฒ function ์์ฐ๊ธฐ๊ณ๋ช (){ this.์์ฑ = ...; .... 2023. 8. 8. JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (31)_ ํจ์ ํ๋ผ๋ฏธํฐ (default, arguments) JS ํจ์์ ํ๋ผ๋ฏธํฐ ์ค default์ argument์ ๋ํด์ ์์๋ณด์. 1. default ํ๋ผ๋ฏธํฐ default ํ๋ผ๋ฏธํฐ ์ฆ, ๊ธฐ๋ณธ๊ฐ์ ํ๋ผ๋ฏธํฐ์ ๊ฐ์ด ์ ๋ฌ๋์ง ์์์ ๊ฒฝ์ฐ ์ด๊ธฐ๊ฐ์ ์ง์ ํด์ฃผ๋ ๊ฒ์ด๋ค. ๋จ์ ๊ฐ ๋ฟ๋ง ์๋ ๋ค์ํ ๊ฒ๋ค์ ์ง์ ํด์ค ์ ์๋ค. ์์ 1. ๋จ์๊ฐ function print(a = 1){ console.log(a); } print(); -------- 1 ์์ 2. ์ฐ์ฐ function print(a, b = a*2){ console.log(a + b); } print(1); print(1, 1); -------- 3 2 ์์ 3. ํจ์ let square = (i)=>{return i**2}; function print(a, b = square(a)){ console.l.. 2023. 8. 7. JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (30)_ Spread Operator JS์ Sperad Operator์ ๋ํด์ ์์๋ณด์. 0. Spread Operator Spread Operator๋ ์ ์ด 3๊ฐ(...)์ธ ์ฐ์ฐ์์ด๋ค. ์ด ์ฐ์ฐ์๋ฅผ ์ด์ฉํด์ ์ฌ๋ฌ ๊ณณ์ ํ์ฉ์ ํ ์ ์๋ค. ๋จผ์ ์์๋ฅผ ํตํด์ ์ฐ์ฐ์์ ๊ธฐ๋ฅ์ ๋ํด์ ์์๋ณด๋ฉด ์์ let a = [1, 2, 3]; let b = "Hello"; console.log(...a); console.log(...b); ์ด์ฒ๋ผ array ํน์ ๋ฌธ์์ด ๊ฐ์ ๊ฒ๋ค์ ํ๋์ฉ ๋ถํดํด์ค๋ค. ํ์ฉ 1. Array ๋ณํฉ & ๋ณต์ฌ ์ฒซ๋ฒ์งธ ํ์ฉ์ array๋ฅผ ํฉ์น๊ฑฐ๋ ๋ณต์ฌํ๋ ๊ฒ์ด๋ค. 1) ๋ณํฉ let a = [1, 2]; let b = [3, 4]; let c = [...a, ...b]; console.log(c); c = [...b, ...a.. 2023. 8. 6. JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (29)_ Tagged Literals ES6๋ถํฐ๋ Tagged Literals ๋ผ๋ ๊ธฐ๋ฅ์ ์ ๊ณตํ๋ค. ์ด์ ๋ํด์ ์์๋ณด์. 1. Tagged Literals Tagged Literals๋ ๋ฌธ์ ํด์ฒด๋ถ์ ๊ธฐ๋ฅ์ ํจ์๋ก ๋ง๋๋ ๊ฒ์ ์ด์ผ๊ธฐํ๋ค. ์ด๋ template literals๋ฅผ ๊ธฐ๋ฐ์ผ๋ก ๊ตฌํํ ์ ์๋ค. ์์ let val = "Korea"; function func(strings, values){ console.log(strings); console.log(values); } func`Welcome to ${val}!` ์์ ์์๋ฅผ ๋ณด๋ฉด func๋ผ๋ ํจ์์ ๋ฐฑํฑ( ` )์ผ๋ก ๊ฐ์ธ์ง ๋ฌธ์์ด์ ๋ถ์ธ ๊ฒ์ ๋ณผ ์ ์๋ค. ์ด๊ฒ์ด ๋ฐ๋ก tagged literals ํจ์๋ฅผ ํธ์ถํ๋ ๋ฐฉ๋ฒ์ด๋ค. tagged literals ํจ์๋ฅผ ์ดํด๋ณด๋ฉด 2๊ฐ์ ํ.. 2023. 8. 5. JS_๋ฌธ๋ฒ (๊ฐ์ธ)_ ๋ณ์ ์ด์ ๋ฆฌ JS์์ ๋ณ์๋ฅผ ๋ง๋ค ๋ 3๊ฐ์ง ๋ฐฉ๋ฒ์ด ์กด์ฌํ๋ค. ์ด๋ค์ ์ ์ธ, ํ ๋น, ๋ฒ์์ ์ธก๋ฉด์์ ์๋ก ๋ค๋ฅธ ํน์ง์ ๊ฐ์ง๋ค! var let const ์ ์ธ ํ ๋น ๋ฒ์ var ์ฌ์ ์ธ O ์ฌํ ๋น O ํจ์ scope let ์ฌ์ ์ธ X ์ฌํ ๋น O ๋ธ๋ก scope const ์ฌ์ ์ธ X ์ฌํ ๋น X (๊ฐ์ฒด ๋ด๋ถ๋ ์๊ด์์ ) ๋ธ๋ก scope - ๋ง์ฝ ๋ณ๊ฒฝ ๋ถ๊ฐ๋ฅํ ๊ฐ์ฒด๋ฅผ ๋ง๋ค๊ณ ์ถ๋ค๋ฉด? ๊ฐ์ฒด๋ ์ด๋ ํ ๋ฐฉ๋ฒ์ผ๋ก ์ ์ธํ์ฌ๋ ๋ด๋ถ ์์์ ๋ํ ์์ ์ ๊ฐ๋ฅํ๋ค. ์ด๋ฅผ ๋ฐฉ์งํ๊ณ ์ถ์ ๊ฒฝ์ฐ์๋ ์๋์ ๋ฐฉ๋ฒ์ ์ด์ฉํ๋ค. Object.freeze( ์์ ๋ถ๊ฐํ๊ฒ ํ๊ณ ์ถ์ ๊ฐ์ฒด๋ช ); ์์ const a = { name : "Kassid"}; Object.freeze(a); a.name = "Hello"; console.log(a); ๋ณ์์ ํธ.. 2023. 8. 4. JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (28)_ Arrow function JS์ Arrow function์ ๋ํด์ ์์๋ณด์. 1. Arrow Function ์ด๋? ํ์ดํ ํจ์๋ ์๋์ ๊ฐ์ด ์ฌ์ฉํ๋ค. let a = ()=> { ... } a(); ๊ธฐ์กด์ function( ){ ... } ๊ณผ ๋ค๋ฅด๊ฒ =>(ํ์ดํ)๋ฅผ ์ด์ฉํ์ฌ ํจ์๋ฅผ ๋ง๋ ๋ค. 2. Arrow Function์ ์ฅ์ ํ์ดํ ํจ์๋ฅผ ์ฌ์ฉํ๋ ์ด์ ๋ ๋ฌด์์ผ๊น? ๋จผ์ ํจ์๋ฅผ ์ด๋ ํ ๊ฒฝ์ฐ์ ๋ง๋ค์ด์ ์ฌ์ฉํ๋์ง ์ดํด๋ณด๋ฉด 1. ์ฝ๋๋ค์ ๊ธฐ๋ฅ์ผ๋ก ๋ฌถ๊ณ ์ถ์ ๋ / 2. ์ ์ถ๋ ฅ ๊ธฐ๋ฅ์ ๋ง๋ค ๋ ์ฌ์ฉํ๋ค. 1) ์ ์ถ๋ ฅ ๊ธฐ๋ฅ์ ์ ํํํ๋ ๋ฌธ๋ฒ์ด๋ค. arrow function์ ํจ์์ ๊ธฐ๋ฅ ์ค ์ ์ถ๋ ฅ ๊ธฐ๋ฅ์ ์ ํํํด์ฃผ๋ ์ฅ์ ์ด ์๋ค. let func = (x, y) => { return x + y } // x, y๋ฅผ ๋ฃ์ผ๋ฉด ๋ .. 2023. 8. 2. JS_๊ธฐ๋ณธ ๋ฌธ๋ฒ (27)_ this ํค์๋ JS์ this ํค์๋์ ๋ํด์ ์์๋ณด์. (4๊ฐ์ง) 0. this ํค์๋์ ์๋ฏธ this ํค์๋๋ ๋ค์ํ ์๋ฏธ๋ฅผ ๊ฐ์ง๊ณ ์๋ค. ๊ทธ ์๋ฏธ๋ ์ฌ์ฉํ๋ ์์น์ ๋ฐ๋ผ ๋ฌ๋ผ์ง๋ค. (์ฌ์ค ์๋์๋..?) 1-1. global์์ ์ฌ์ฉ & ์ผ๋ฐ(์ ์ญ) ํจ์์์ ์ฌ์ฉ -> window ๋จผ์ ๊ฐ์ฅ ์์ ์์น์์ this ํค์๋๋ฅผ ์ฝ์์์ ํ์ธํด๋ณด๋ฉด ์๋์ ๊ฐ๋ค. window๋ผ๋ ๊ฐ์ฒด๋ฅผ ๋ฐํํ๋ค. +) window๋? - ๋ชจ๋ ์ ์ญ๋ณ์, ํจ์, DOM์ ๊ด๋ฆฌํ๋ ์ ์ญ๊ฐ์ฒด! - ์๋ฅผ๋ค์ด ์ ์ญ๋ณ์๋ฅผ ์์ฑํ๋ฉด window ์์ ์์ฑ๋๋ ๊ฒ์ด๋ค. 1-2. strict mode์ผ๋ ์ผ๋ฐ ํจ์ ์์์ ์ฌ์ฉ -> undefined 'use strict' 'use strict'๋ผ๋ ํค์๋๋ฅผ ์ต์๋จ์ ์ถ๊ฐํ๋ฉด strict ๋ชจ๋๋ก ์์ฑํ .. 2023. 8. 1. [React] 2-1. array state ์ ๋ ฌํ๊ธฐ ( .sort()ํ์ฉ) ์ด์ ๊ธ โผ ๋๋ณด๊ธฐ 0. 2023.05.05 - [๐ | WEB DEV/React] - [React] 0. React๋ฅผ ์ฌ์ฉํ๋ ์ด์ & ์ด๊ธฐ ์ธํ 1. 2023.05.07 - [๐ | WEB DEV/React] - [React] 1. JSX 2. 2023.05.26 - [๐ | WEB DEV/React] - [React] 2. state (๋ณ์, array, object) array state๋ฅผ ์ ๋ ฌํ๊ณ ์ถ์ ๋๋ ์ด๋ป๊ฒ ํด์ผํ ๊น? ๊ฐ์ฅ ๋ณดํธ์ ์ธ ๋ฐฉ๋ฒ์ธ sort()๋ฉ์๋๋ฅผ ์ด์ฉํด๋ณด์. 1. sort() ํ์ฉํ์ฌ array state ์ ๋ ฌํ๊ธฐ let [music, setMusic] = useState( [{"type": "Rock", "title": "Summer", "singer": "The Volun.. 2023. 5. 27. ์ด์ 1 2 3 4 ยทยทยท 6 ๋ค์ ๋ฐ์ํ