ν•¨μˆ˜μ„ μ–Έμ‹ VS ν•¨μˆ˜ν‘œν˜„μ‹μ˜ ν˜Έμ΄μŠ€νŒ…(Hoisting)

ν˜Έμ΄μŠ€νŒ…(Hoisting)은 JavaScriptμ—μ„œ λ³€μˆ˜μ™€ ν•¨μˆ˜ 선언이 μ΅œμƒλ‹¨μœΌλ‘œ λŒμ–΄μ˜¬λ €μ§€λŠ” ν˜„μƒμ„ λ§ν•©λ‹ˆλ‹€. ν•˜μ§€λ§Œ ν•¨μˆ˜ 선언식과 ν•¨μˆ˜ ν‘œν˜„μ‹μ€ λ‹€λ₯΄κ²Œ λ™μž‘ν•˜λ―€λ‘œ μ£Όμ˜κ°€ ν•„μš”ν•©λ‹ˆλ‹€.

πŸ“ ν•¨μˆ˜ 선언식

ν•¨μˆ˜ 선언식은 전체가 ν˜Έμ΄μŠ€νŒ…λ˜κΈ° λ•Œλ¬Έμ— ν•¨μˆ˜λ₯Ό μ„ μ–Έν•˜κΈ° 전에 ν˜ΈμΆœν•΄λ„ μ •μƒμ μœΌλ‘œ λ™μž‘ν•©λ‹ˆλ‹€.
console.log(zero); // undefined
sayWow(); // 'wow'

function sayWow() {
  console.log('wow');
}

var zero = 'zero';
        
ν•¨μˆ˜ 선언식인 sayWowλŠ” 전체가 λŒμ–΄μ˜¬λ €μ Έμ„œ 호좜 전에도 ν•¨μˆ˜κ°€ μ •μ˜λ˜μ–΄ μžˆμŠ΅λ‹ˆλ‹€. μ•„λž˜ sayWowν•¨μˆ˜κ°€ μƒλ‹¨μœΌλ‘œ λŒμ—¬ μ˜¬λ €μ§„κ²ƒκ³Ό 같은 μ˜λ―Έκ°€ λ©λ‹ˆλ‹€.
function sayWow() {
  console.log('wow');
}

var zero;
console.log(zero);
sayWow();
zero = 'zero';

πŸ“ ν•¨μˆ˜ ν‘œν˜„μ‹

ν•¨μˆ˜ ν‘œν˜„μ‹μ€ λ³€μˆ˜λ§Œ λŒμ–΄μ˜¬λ €μ§€κ³  ν•¨μˆ˜μ˜ 할당은 κ·ΈλŒ€λ‘œ μœ μ§€λ˜κΈ° λ•Œλ¬Έμ— ν˜ΈμΆœν•˜κΈ° 전에 λ³€μˆ˜μ— ν•¨μˆ˜λ₯Ό ν• λ‹Ήν•΄μ•Ό ν•©λ‹ˆλ‹€.

sayWow(); // μ—λŸ¬
sayYeah(); // μ—λŸ¬

var sayYeah = function() {
  console.log('yeah');
}

function sayWow() {
  console.log('wow');
}
ν•¨μˆ˜ ν‘œν˜„μ‹μΈ sayYeahλŠ” λ³€μˆ˜ μ„ μ–Έλ§Œ ν˜Έμ΄μŠ€νŒ…λ˜μ–΄ sayYeah()λ₯Ό ν˜ΈμΆœν•˜κΈ° 전에 ν•¨μˆ˜λ₯Ό ν• λ‹Ήν•΄μ£Όμ§€ μ•ŠμœΌλ©΄ μ—λŸ¬κ°€ λ°œμƒν•©λ‹ˆλ‹€. μ•„λž˜λŠ” sayYeahκ°€ ν˜Έμ΄μŠ€νŒ…λ˜μ–΄ μƒλ‹¨μœΌλ‘œ μ˜¬λ €μ‘ŒμœΌλ‚˜ 값이 ν• λ‹Ήλ˜μ§€ μ•Šμ•„ ν˜ΈμΆœν•˜λ©΄ μ—λŸ¬λ₯Ό λ°œμƒμ‹œν‚΅λ‹ˆλ‹€.
var sayYeah;
sayYeah(); // μ—λŸ¬

sayYeah = function() {
  console.log('yeah');
}

function sayWow() {
  console.log('wow');
}
        
ν•¨μˆ˜ ν‘œν˜„μ‹μ€ λ³€μˆ˜μ— ν•¨μˆ˜λ₯Ό ν• λ‹Ήν•˜λŠ” ν˜•νƒœμ΄λ―€λ‘œ λ³€μˆ˜ ν˜Έμ΄μŠ€νŒ…μ€ λ°œμƒν•˜μ§€λ§Œ ν•¨μˆ˜μ˜ 할당은 μœ μ§€λ˜μ§€ μ•Šμ•„ ν•¨μˆ˜λ₯Ό λ¨Όμ € ν˜ΈμΆœν•  수 μ—†μŠ΅λ‹ˆλ‹€.
μ°Έκ³ ν•˜λ©΄ 쒋은 링크
https://www.zerocho.com/category/JavaScript/post/5741d96d094da4986bc950a0