βμ μ§ λ³΄μλ₯Ό μ½κ² νλ μ£Όμ κΈ°λ₯μ μ§μμ±μ λλ€. μ§μμ±μ μμ€ μ½λμ μμ λΆλΆλ§μ λ³΄κ³ λ ν΄λΉ μμ€λ₯Ό μ΄ν΄ν μ μκ² ν΄μ£Όλ νΉμ±μ λλ€.β β 리μ²λ κ°λΈλ¦¬μ
νλμ μ§μμ±(Locality of Behaviour, LoB)μ λ€μκ³Ό κ°μ μμΉμ λλ€:
μ½λ λ¨μμ λμμ ν΄λΉ μ½λ λ¨μλ§μ λ³΄κ³ λ μ΅λν λͺ ννκ² μ΄ν΄ν μ μμ΄μΌ νλ€.
LoB μμΉμ 리μ²λ κ°λΈλ¦¬μμ μΈμ©λ¬Έμμ λμ¨ λ¨μν μ²λ°©μ 곡μμ λλ€. κ°λ₯ν ν, κ·Έλ¦¬κ³ λ€λ₯Έ κ³ λ €μ¬νλ€κ³Ό κ· νμ λ§μΆλ©΄μ, κ°λ°μλ€μ μ½λ μμμ λμμ λͺ ννκ² νλ €κ³ λ Έλ ₯ν΄μΌ ν©λλ€.
HTMLμμ λ κ°μ§ λ€λ₯Έ AJAX μμ² κ΅¬ν λ°©μμ κ³ λ €ν΄λ΄ μλ€. 첫 λ²μ§Έλ htmxλ₯Ό μ¬μ©νλ κ²½μ°μ λλ€:
<button hx-get="/clicked">Click Me</button>
λ λ²μ§Έλ jQueryλ₯Ό μ¬μ©νλ κ²½μ°μ λλ€:
$("#d1").on("click", function(){
$.ajax({
/* AJAX μ΅μ
λ€... */
});
});
<button id="d1">Click Me</button>
첫 λ²μ§Έ κ²½μ°μμ button
μμμ λμμ λͺ
ννκ² λλ¬λλ©°, LoB μμΉμ μΆ©μ‘±ν©λλ€.
λ λ²μ§Έ κ²½μ°μμλ button
μμμ λμμ΄ μ¬λ¬ νμΌμ λΆμ°λμ΄ μμ΅λλ€. λ²νΌμ΄ μ νν μ΄λ€ λμμ νλμ§ μκΈ° μν΄μλ μ½λ λ² μ΄μ€ μ 체λ₯Ό μ΄ν΄ν΄μΌ ν©λλ€.
μ΄λ¬ν β거리μ μ€νΈν€ μ‘μ
βμ μ μ§λ³΄μ λ¬Έμ μ μμΈμ΄ λλ©°, κ°λ°μλ€μ΄ μ½λ λ² μ΄μ€λ₯Ό μ΄ν΄νλ λ° λ°©ν΄κ° λ©λλ€.
htmx μμλ μ’μ νλμ μ§μμ±μ 보μ¬μ£Όλ©°, jQuery μμλ λμ νλμ μ§μμ±μ 보μ¬μ€λλ€.
νλμ μ§μμ±μ λν μΌλ°μ μΈ λ°λ μ견μ, μ΄κ²μ΄ μ½λ λ¨μ λ΄μμ ꡬν μΈλΆ μ¬νμ μΈλΌμΈννμ¬ μ½λ λ¨μλ₯Ό λ μΆμμ μ΄κ³ λ μ·¨μ½νκ² λ§λ λ€λ κ²μ λλ€. κ·Έλ¬λ νλμ ꡬνμ μΈλΌμΈννλ κ²κ³Ό νλμ νΈμΆ(λλ μ μΈ)μ μΈλΌμΈννλ κ²μ μ€μν μ°¨μ΄κ° μλ€λ μ μ μ΄ν΄νλ κ²μ΄ μ€μν©λλ€.
λλΆλΆμ νλ‘κ·Έλλ° μΈμ΄μμ ν¨μλ μ μΈκ³Ό νΈμΆ μ§μ μ΄ κ΅¬λΆλ©λλ€. μ’μ ν¨μλ ꡬν μΈλΆ μ¬νμ μΆμννμ§λ§, λν λͺ νν λ°©μμΌλ‘ νΈμΆλμ΄ κ±°λ¦¬μ μ€νΈν€ μ‘μ μμ΄ λμν©λλ€.
μμμ λμμ λͺ ννκ² νλ κ²μ, μ‘°κ±΄μ΄ λμΌνλ€λ©΄, μ’μ μΌμ΄μ§λ§, μ΅μ’ κ°λ°μμ νΉν νλ μμν¬ κ°λ°μλ LoBλ₯Ό μ½κ² μ μ§νκ³ κ°λ μ μΌλ‘λ κΉλνκ² λ§λ€κΈ° μν΄ λ Έλ ₯ν΄μΌ ν©λλ€.
LoBλ μ’ μ’ λ€λ₯Έ μννΈμ¨μ΄ κ°λ° μμΉλ€κ³Ό μΆ©λν©λλ€. μ€μν λ κ°μ§ μμΉμ λ€μκ³Ό κ°μ΅λλ€:
μννΈμ¨μ΄ κ°λ°μλ€μ μΌλ°μ μΌλ‘ μ½λλ λ°μ΄ν°μμ μ€λ³΅μ νΌνλ €κ³ λ Έλ ₯ν©λλ€. μ΄λ₯Ό βDRY μ μ§βλΌκ³ λΆλ₯΄λ©°, μ¦ βμκΈ° μμ μ λ°λ³΅νμ§ λ§λΌβλ μλ―Έμ λλ€. μλ₯Ό λ€μ΄, htmxλ λΆλͺ¨ μμμ λ§μ μμ±μ λ°°μΉνμ¬ μμ μμμμ μ΄λ¬ν μμ±μ λ°λ³΅νμ§ μλλ‘ ν μ μμ΅λλ€. μ΄λ DRYλ₯Ό μ°μ μν LoBμ μλ°μ΄λ©°, μ΄λ¬ν νΈλ μ΄λμ€νλ κ°λ°μλ€μ΄ μ μ€νκ² κ²°μ ν΄μΌ ν©λλ€.
νλμ΄ μ½λ λ¨μμμ λ©μ΄μ§μλ‘, LoBμ μλ°μ λμ± μ¬κ°ν΄μ§λλ€. νλμ΄ μ½λ λ¨μμμ λͺ μ€ λ¨μ΄μ Έ μλ κ²½μ°, λ³λ‘ μ¬κ°νμ§ μμ§λ§, μ½λ λ¨μμμ ν νμ΄μ§ μ΄μ λ¨μ΄μ Έ μλ κ²½μ°, κ·Έλ¦¬κ³ λ³λμ νμΌμ μλ κ²½μ°μλ λ μ¬κ°ν΄μ§λλ€.
μ΄λ μ격ν κ·μΉμ΄ μλλΌ, μννΈμ¨μ΄ κ°λ°μλ€μ΄ μ£Όκ΄μ μΌλ‘ μ νν΄μΌ νλ νΈλ μ΄λμ€νμ λλ€.
κ΄μ¬μ¬μ λΆλ¦¬λ μ»΄ν¨ν° νλ‘κ·Έλ¨μ λ³κ°μ κ΄μ¬μ¬λ‘ λΆλ¦¬νλ μ€κ³ μμΉμ λλ€. HTML, CSS, Javascriptλ₯Ό λΆλ¦¬νλ κ²μ΄ κ·Έ μμ λλ€. μ΅κ·Όμλ μ€νμΌμ μΈλΌμΈννλ κ²½ν₯μ΄ μ¦κ°νκ³ μμ§λ§, μ΄μ κ΄λ ¨νμ¬ SoCλ₯Ό μ§μ§νλ κ°λ ₯ν λ Όκ±°λ€μ΄ μ¬μ ν μ‘΄μ¬ν©λλ€.
κ·Έλ¬λ SoCλ LoBμ μΆ©λν©λλ€. CSS νμΌμ μ‘°μ ν¨μΌλ‘μ¨ μμμ μΈκ΄ λ° λμμ΄ ν¬κ² λ³κ²½λ μ μμΌλ©°, μ΄λ¬ν ν° λ³κ²½μ΄ μ΄λμμ λ°μνλμ§ λͺ ννμ§ μμ΅λλ€. λκ΅¬κ° μ΄λ μ λ λμμ΄ λ μ μμ§λ§, μ¬μ ν β거리μ μ€νΈν€ μ‘μ βμ΄ λ°μνκ³ μμ΅λλ€.
λ€μ λ§νμ§λ§, SoCλ₯Ό μ λ©΄μ μΌλ‘ λΉλνλ κ²μ΄ μλλΌ, μ½λλ₯Ό ꡬ쑰νν λ μ£Όκ΄μ μΈ νΈλ μ΄λμ€νκ° νμνλ€λ κ²μ λ§νκ³ μ ν©λλ€. μ΅κ·Όμ μΈλΌμΈ μ€νμΌμ΄ λ λ§μ΄ μ¬μ©λκ³ μλ κ²μ κ°λ°μλ€ μ¬μ΄μμ SoCμ λν μ§μ§κ° κ°μνκ³ μμμ λνλ λλ€.
LoBλ μ½λ λ² μ΄μ€λ₯Ό λ μΈκ°μ μ΄κ³ μ μ§λ³΄μ κ°λ₯νκ² λ§λλ μ£Όκ΄μ μΈ μννΈμ¨μ΄ μ€κ³ μμΉμ λλ€. λ€λ₯Έ μ€κ³ μμΉλ€κ³Όμ νΈλ μ΄λμ€νκ° νμνλ©°, μ½λ λ¨μκ° μμ±λ μμ€ν μ μ ν μ¬νμ κ³ λ €ν΄μΌ νμ§λ§, μ€μ©μ μΌ μ μλ ν μ΄ μμΉμ μ€μνλ©΄ μννΈμ¨μ΄μ μ μ§λ³΄μμ±, νμ§, μ§μ κ°λ₯μ±μ λμΌ μ μμ΅λλ€.