Skip to content

jquery_in_depth_1

KyusungDev edited this page May 17, 2017 · 7 revisions

μš”μ†Œ μ„ νƒν•˜κΈ°

jQueryλŠ” '효과적인 선택'을 μœ„ν•΄ μ„ νƒμž(selector)λ₯Ό μ‚¬μš©ν•œλ‹€. μ„ νƒμžλŠ” μ›λž˜ CSSμ—μ„œ λ””μžμΈμ„ μ μš©ν•  HTML λ§ˆν¬μ—…μ„ μ„ νƒν•˜κΈ° μœ„ν•΄ μ‚¬μš©λ˜μ—ˆμ§€λ§Œ, κ°„λž΅ν•˜λ©΄μ„œλ„ κ°•λ ₯ν•œ κΈ°λŠ₯으둜 jQuery와 같은 λΌμ΄λΈŒλŸ¬λ¦¬μ—μ„œλ„ HTML μš”μ†Œ 선택을 μœ„ν•΄ μ‚¬μš©λœλ‹€.

κΈ°λ³Έ μ„ νƒμž

μ„ νƒμž μ‚¬μš© 예 μ„€λͺ…
전체 μ„ νƒμž $("*") λͺ¨λ“  μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
ID μ„ νƒμž $("#content") μ§€μ •ν•œ IDλ₯Ό κ°€μ§„ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
클래슀 μ„ νƒμž $(".title") μ§€μ •ν•œ νƒœκ·Έ 이름이 μ£Όμ–΄μ§„ μš”μ†Œλ₯Ό λͺ¨λ‘ μ„ νƒν•œλ‹€.
νƒœκ·Έ μ„ νƒμž $("div") μ§€μ •ν•œ 클래슀 이름이 μ£Όμ–΄μ§„ μš”μ†Œλ₯Ό λͺ¨λ‘ μ„ νƒν•œλ‹€.

AND μ‘°ν•©
$("div#a") : νƒœκ·Έλͺ…이 divμ΄λ©΄μ„œ λ™μ‹œμ— IDκ°€ a인 것을 μ„ νƒν•œλ‹€.
$(".test.main") : 클래슀λͺ…이 test와 main이 λͺ¨λ‘ λΆ€μ—¬λœ 것을 μ„ νƒν•œλ‹€.

OR μ‘°ν•©
$("#a, h1") : IDκ°€ aμ΄κ±°λ‚˜ νƒœκ·Έλͺ…이 h1인 것을 μ„ νƒν•œλ‹€.

계측 μ„ νƒμž

HTML DOM 트리의 계측적 ꡬ쑰λ₯Ό μ΄μš©ν•œ μ„ νƒμžμ΄λ‹€. 4κ°€μ§€ μ„ νƒμžκ°€ μ œκ³΅λœλ‹€.

μ„ νƒμž μ‚¬μš© 예 μ„€λͺ…
μžμ‹ $("#a > h1") 직계 μžμ‹ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
(#a μš”μ†Œμ˜ 직계 μžμ‹ h1)
후손 $("#a h1") 후손 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
(#a μš”μ†Œμ— ν¬ν•¨λœ 후손 쀑 h1)
λ‹€μŒ 인접 $("#a + h1") #a μš”μ†Œμ˜ λ™λ“±ν•œ 계측 κ΅¬μ‘°μ—μ„œ
λ‹€μŒ μš”μ†Œκ°€ h1인 것을 μ„ νƒν•œλ‹€.
λ‹€μŒ ν˜•μ œ $("#a ~ h1") #a μš”μ†Œμ˜ λ™λ“±ν•œ 계측 κ΅¬μ‘°μ—μ„œ
λ‹€μŒ ν˜•μ œ μš”μ†Œμ€‘ h1 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.

νŠΉμ„± μ„ νƒμž

HTML μš”μ†Œμ˜ νŠΉμ„±μ„ μ΄μš©ν•˜λŠ” μ„ νƒμžμ΄λ‹€. μ°Ύμ•„μ„œ μ„ νƒν•˜λŠ” 속도가 느리기 λ•Œλ¬Έμ— κΌ­ ν•„μš”ν•œ κ²½μš°μ—λ§Œ μ‚¬μš©ν•˜λŠ” 것이 λ°”λžŒμ§ν•˜λ‹€. 특히 κ΅¬ν˜• λΈŒλΌμš°μ €μ—μ„œλŠ” μ„±λŠ₯ 차이가 ν™•μ—°ν•˜κ²Œ λ“œλŸ¬λ‚˜κΈ° λ•Œλ¬Έμ— μ£Όμ˜ν•΄μ„œ μ‚¬μš©ν•΄μ•Ό ν•œλ‹€.

μ„ νƒμž μ‚¬μš© 예 μ„€λͺ…
[νŠΉμ„±λͺ…] $("[readonly]") νŠΉμ„±κ°’κ³ΌλŠ” 관계없이 [readonly]
νŠΉμ„±μ„ κ°€μ§„ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…=κ°’] $("name='abc'") name νŠΉμ„±μ— 값이
abc인 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…*=κ°’] $("src='icon']") src νŠΉμ„±μ— icon λ¬Έμžκ°€
ν¬ν•¨λœ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…~=κ°’] $("alt~='날씨'") alt νŠΉμ„±μ— '날씨'λΌλŠ” λ¬Έμžκ°€
λ‹¨μ–΄λ‘œμ„œ ν¬ν•¨λœκ²ƒλ§Œ μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…|=κ°’] $("hreflang|='en'") hreflang νŠΉμ„±μ˜ 접두어가
en인 것을 μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…^=κ°’] $("[href^='https://']") https://둜 μ‹œμž‘ν•˜λŠ”
href νŠΉμ„±κ°’μ„ κ°€μ§„ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…$=κ°’] $("[href$='.com']") '.com'으둜 λλ‚˜λŠ”
href νŠΉμ„±κ°’μ„ κ°€μ§„ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
[νŠΉμ„±λͺ…!=κ°’] $("input[name!='name']") input νƒœκ·Έμ΄λ©΄μ„œ name νŠΉμ„±μ΄
'name'이 μ•„λ‹Œ 것을 μ„ νƒν•œλ‹€.

ν•„ν„° μ„ νƒμž

ν•„ν„° μ„ νƒμžλŠ” 콜둠(:) 기호둜 μ‹œμž‘ν•˜λŠ” λ¬Έμžμ—΄ ν˜•μ‹μ„ μ‚¬μš©ν•œλ‹€.

μœ„μΉ˜ ν•„ν„° μ„ νƒμž

μœ„μΉ˜ ν•„ν„° μ„ νƒμžλŠ” μ—¬λŸ¬ 개의 μš”μ†Œ μ€‘μ—μ„œ νŠΉμ • μœ„μΉ˜μ˜ μš”μ†Œλ₯Ό 선택할 λ•Œ μ‚¬μš©ν•œλ‹€.

μ„ νƒμž μ„€λͺ…
:first 첫번째 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:last λ§ˆμ§€λ§‰ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:eq(i) i번 인덱슀 μœ„μΉ˜μ˜ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:gt(i) i번 μœ„μΉ˜ μ΄ν›„μ˜ λͺ¨λ“  μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:lt(i) i번 μœ„μΉ˜ μ΄μ „μ˜ λͺ¨λ“  μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:even 짝수 번 인덱슀 μœ„μΉ˜μ˜ λͺ¨λ“  μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:odd ν™€μˆ˜ 번 인덱슀 μœ„μΉ˜μ˜ λͺ¨λ“  μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.

μž…λ ₯ 폼 ν•„ν„° μ„ νƒμž

μž…λ ₯ 폼 ν•„ν„° μ„ νƒμžλŠ” μ‚¬μš©μžμ—κ²Œ μž…λ ₯ λ°›κΈ° μœ„ν•΄ μ‚¬μš©λ˜λŠ” HTML μš”μ†Œλ₯Ό μ„ νƒν•˜λŠ” κΈ°λŠ₯을 μ œκ³΅ν•œλ‹€. λ‹€λ₯Έ μ„ νƒμžλ‘œ λŒ€μ²΄λ„ κ°€λŠ₯ν•˜λ‹€. 예λ₯Ό λ“€μ–΄ ':checkbox'의 경우 '[type=checkbox]'와 λ™μΌν•œ κΈ°λŠ₯을 μ œκ³΅ν•˜λ―€λ‘œ μ΅μˆ™ν•œ 것을 μ‚¬μš©ν•˜λ©΄ λœλ‹€.

μ„ νƒμž μ„€λͺ…
:button λ²„νŠΌ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:checkbox type='checkbox'인 μ²΄ν¬λ°•μŠ€ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:text type='text'인 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:image type='image'인 input μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:file type='file'인 input μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:password type='password'인 input μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:radio type='radio'인 radio button μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:reset type='reset'인 input μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:submit type='submit'인 input μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:input λͺ¨λ“  μž…λ ₯ 폼 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.

λ³΄μž„ μƒνƒœ ν•„ν„° μ„ νƒμž

λ³΄μž„ μƒνƒœμ— 따라 μš”μ†Œλ₯Ό μ„ νƒν•˜λŠ” κΈ°λŠ₯을 μ œκ³΅ν•˜λ©° 두 κ°€μ§€κ°€ μ œκ³΅λœλ‹€.

μ„ νƒμž μ„€λͺ…
:visible 화면에 λ³΄μ΄λŠ” μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:hidden 화면에 보이지 μ•ŠλŠ” μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.

μžμ‹ ν•„ν„° μ„ νƒμž

μžμ‹ ν•„ν„° μ„ νƒμžλŠ” μžμ‹ μš”μ†Œ 쀑 일뢀 μš”μ†Œλ₯Ό μ„ νƒν•˜λŠ” κΈ°λŠ₯을 μ œκ³΅ν•œλ‹€.

μ„ νƒμž μ„€λͺ…
:first-child μžμ‹ μš”μ†Œ 쀑 첫번째 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:first-of-type λ™μΌν•œ μš”μ†Œλͺ…을 κ°€μ§€λŠ” ν˜•μ œ μš”μ†Œ μ‚¬μ΄μ—μ„œ 첫 번째 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:last-child μžμ‹ μš”μ†Œμ€‘ λ§ˆμ§€λ§‰ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:last-of-type λ™μΌν•œ μš”μ†Œλͺ…을 κ°€μ§€λŠ” ν˜•μ œ μš”μ†Œ μ‚¬μ΄μ—μ„œ λ§ˆμ§€λ§‰ μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:nth-child() μžμ‹ μš”μ†Œ 쀑 n번째 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:nth-last-child() μžμ‹ μš”μ†Œμ€‘ λ§ˆμ§€λ§‰μ—μ„œ n번째 μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.

μ½˜ν…νŠΈ ν•„ν„° μ„ νƒμž

μ½˜ν…νŠΈ ν•„ν„° μ„ νƒμžλŠ” μ½˜ν…μΈ  μ˜μ—­κ°’μœΌλ‘œ 필터링 ν•˜λŠ” μ„ νƒμžμ΄λ‹€.

μ„ νƒμž μ„€λͺ…
:contains() μ§€μ •ν•œ λ¬Έμžμ—΄μ„ ν¬ν•¨ν•˜λŠ” μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:empty μ½˜ν…νŠΈ μ˜μ—­μ΄ λΉ„μ–΄μžˆλŠ” μš”μ†Œλ§Œ μ„ νƒν•œλ‹€.
:has() has() 내뢀에 μ§€μ •λœ μ„ νƒμžλ‘œ 선택될 수 μžˆλŠ”
μš”μ†Œλ₯Ό ν¬ν•¨ν•˜κ³  μžˆλŠ” μš”μ†Œλ₯Ό μ„ νƒν•œλ‹€.
:not() not()에 ν¬ν•¨λœ μ„ νƒμžμ— λΆ€ν•©λ˜μ§€ μ•ŠλŠ” μš”μ†Œλ§Œ μ„ νƒν•œλ‹€.
:parent 적어도 ν•˜λ‚˜μ˜ μžμ‹ μš”μ†Œλ₯Ό κ°€μ§€κ³  μžˆλŠ” μš”μ†Œλ§Œ μ„ νƒν•œλ‹€.

Clone this wiki locally