-
μ νΈμΆ "μ€ν", μ½λ°± "ν"μΌκΉ?π Browser 2023. 2. 20. 19:13
π μκ°
κ³Όκ±°μ μμ±ν λΈλΌμ°μ ꡬ쑰/λμ μ리 ν¬μ€ν μ μ 리νλ€κ°, λΆλ¦¬ν μ μλ μ£Όμ λ₯Ό λ°κ²¬νμκ³ , μμ¦ μ?λΌλ μ§λ¬Έμ λμ§κ³ λλ΅νλ μ°μ΅μ νκ³ μκΈ°μ κ°λ¨ν μ λ¦¬ν΄ λ³΄μλ€.
π νΈμΆ μ€ν, μ½λ°± νκ° κ°κ°μ μλ£νμ μ¬μ©νλ μ΄μ ?
- μ νΈμΆ μ€νμμ μ€ν μλ£νμ΄ μ¬μ©λ κΉμ?
μλ μμ μ λ΄λΆ λμ κ³Όμ μ λ°νμ νκ²½μ κ° μ₯μΉκ° κ°κ°μ μλ£κ΅¬μ‘°λ₯Ό μ¬μ©νλ μ΄μ μ λμ ν΄ μ€λͺ ν΄ λ³΄κ² λ€.
function level1(){ console.log(1) // -- (4) } function level2(){ level1() // -- (2) console.log(2) // -- (3) } function welcome(){ console.log("welcome!") } level2() // -- (0) welcome() // -- (1) // 1 // 2 // welcome!
μλ°μ€ν¬λ¦½νΈλ λκΈ°μ μΌλ‘ μλνκΈ° λλ¬Έμ (0) λ² μ½λκ° λͺ¨λ μ€νλ νμ (1) λ² μ½λκ° μ€νλλ€.
(0) λ² μ½λκ° μ€νλλ©΄μ μΈν°ν리ν°λ ν¨μ level2μ κ·Έ μ€ν λ¬Έλ§₯μ νΈμΆμ€νμ μΆκ°νκ³ , (2) λ² ν¨μκ° μ€ν λ¬Έλ§₯μ λ΄κΈ°κ³ , (2) λ²κ³Ό (3) λ² μ½λλ λμμ μ²λ¦¬λ μ μκΈ°μ (2) λ²μ΄ λλκΈ° μ κΉμ§ (3) λ‘κ·Έλ¬Έμ μ€νλμ§ μλλ€. (2) μ½λκ° μ€νλλ©΄μ level() ν¨μμ κ·Έ λ΄λΆ μ€νλ¬Έ log(1)μ΄ μ°¨λ‘λλ‘ μ€νμ μμ΄κ² λκ³ , κ°μ₯ λ§μ§λ§ λ€μ΄μ¨ log(1)λΆν° μ²λ¦¬λλ€.
μ΄λ κ² μλ°μ€ν¬λ¦½νΈ νμ€ν¬λ κ°μ₯ λ΄λΆμ μλ μ€νλ¬Έμ΄ μ’ λ£λμ΄μΌ μ°¨λ‘λλ‘ κ·Έ μΈλΆλ₯Ό κ°μΈλ μ€νλ¬Έμ΄ μ’ λ£λλ μ¬κ·μ μΈ ννλ₯Ό λ€λ€. κ·Έλ κΈ°μ κ°μ₯ λ§μ§λ§ λ€μ΄μ¨ μ€νλ¬Έμ κ°μ₯ λ¨Όμ μ²λ¦¬ν΄ μ£ΌκΈ° μνμ¬ First In Last Out νΉμ±μ κ°μ§ μ€ν μλ£νμ΄ μ±νλ κ²μ΄λ€ λ λ
- κ·Έλ λ€λ©΄ μ½λ°± νλ...?
μ½λ°± νλ (μ¬μ€ μΈκΈνκΈ°λ λ―Όλ§ν μ λλ‘ μ¬μ© μ΄μ κ° λͺ ννμ§λ§) Web Apiκ° μ½λ°± ν¨μλ₯Ό λ°νν μμλλ‘ μ²λ¦¬νκΈ° μν΄ First In First Out νΉμ±μ κ°μ§ ν μλ£νμ΄ μ¬μ©λμμ΅λλ€ λ λ λ
function cb1(){ console.log(1) } function cb2(){ console.log(2) } function cb3(){ console.log(3) } setTimeout(cb1, 0) setTimeout(cb2, 0) setTimeout(cb3, 0) // 1 // 2 // 3
'π Browser' μΉ΄ν κ³ λ¦¬μ λ€λ₯Έ κΈ