j

jQuery를 이용한 HTML DOM 접근 - 기본 셀렉터 2

· 12년 전 · 1613

원하는 개체를 쉽고 편하게 선택하자 - 셀렉터

셀렉터의 종류

셀렉터 표현 방법

All Selector

$("*")

ID Selector

$("#id")

Element Selector

$("elementName")

Class Selector

$(".className")

Multiple Selector

$("selector1, selector2, selector3, selectorN")

 

지난 시간에 이어 기본이 되는 셀렉터의 나머지 부분인 클래스와 여러가지 셀렉터를 조합하여 요소에 접근하고, 개체를 탐색 선택하는 방법에 대한 이야기를 진행 하도록 하겠습니다.

 

Class Selector : $(“.class”)

자바스크립트의 getElementByClassName()과 동일한 역할을 하고 있는 셀렉터 입니다.

getElementByClassName() 메서드의 경우 몇몇 브라우저에서 지원을 하고 있지 않기 때문에 크로스브라우징을 지원해야 하는 개발이라면 올바르게 동작하지 않는 문제가 발생할 수 있습니다.

IE8 이하 버전에서는 지원을 하고 있지 않다고 하며, IE9과 HTML의 차세대 버전인 HTML5에서는 기본적으로 지원을 한다고 합니다.

 

프런트 부분을 개발하다 보면 위와 같은 문제로 인하여, 많은 개발자가 고민하고 해결책을 찾다가 많은 시간을 허비하는 경우가 상당합니다. 문제를 찾기위해 자바스크립트 디버깅을 해 보지만 상당한 노가다를 필요로 하는 경우도 많을 뿐더러 브라우저마다 에러를 내는 형식이 다르기 때문에 상당한 골치 덩어리 입니다.

 

여기서 다시 한번 jQuery의 강점인 크로스브라우징에 대한 강조를,,, jQuery의 ClassSelector의 경우 현존하는 대부분의 브라우저에서 사용이 가능하오니, 위와 같은 문제를 미연에 방지 할 수 있으며 이러한 문제에 대해 고민을 할 필요 조차 없게 됩니다.

 

다시 본론으로 들어가서 Class Selector에 대해 알아 보기로 하겠습니다.

다음은 문서(HTML)내의 클래스명이 myClass인 요소를 모두 찾아 테두리의 색상을 변경하는 예제입니다.

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>jQuery Selector</title>
    <link href="../Styles/Site.css" rel="stylesheet" type="text/css" />
    <style>
        div,span { 
            width:100px; height:40px; float:left; padding:10px; margin:10px; 
            background-color:#EEEEEE; 
        }
    </style>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            //Class가 myClass인 요소를 찾아 테두리를 "blue"로 변경합니다.
            $(".myClass").css("border", "2px solid blue");
        });
    </script>
</head>
<body style="padding:10px;">
    <h2>jQuery 시작 Selector</h2>
    <p>jQuery에 대한 자세한 내용을 보려면 jquery.com 을 방문하세요.</p>        
    <span class="myClass">SPAN class="myClass"</span>
    <div>DIV</div>    
    <span>SPAN</span>
    <div class="myClass">DIV class="myClass"</div>
</body>
</html>

 

03_006.jpg

 

 

 

Multiple, Complex Selector :

$(“selector1, selector2, selectorN”)
$(“#id div.class”)

앞서 설명한 셀렉터의 나열이나 조합을 통하여 개발자가 원하는 개체를 보다 쉽고 정확하고 빠르게 탐색 할 수 있습니다.

셀렉터를 “,” 통하여 나열할 경우 각각의 셀렉터를 통해 탐색된 개체의 집합을 반환하며, 셀렉터의 조합을 통하여 탐색을 했을 경우 각 셀렉터의 교집합 조건의 개체가 탐색되어 반환 됩니다.


$(“#content”, “div”, “a”, “.myclass”) 경우 ID의 값이 “content”인 개체, “div”, “a” 태그를 가지는 개체, 클래스 명이 “myClass”인 개체를 탐색하여 반환을 하게 되는 반면 $(“div.myClass”)의 경우 “div” 태그로 구성되었으며 동시에 클래스 명이 “myClass”인 개체를 반환합니다.


다음 두가지 예제를 통해 두 가지 셀렉터의 동작과 차이점을 알아 보도록 하겠습니다.

 

첫 번째 예제 : ID값이 Conetnt이며 DIV 요소를 찾아 테두리를 파랑색으로 변경합니다.

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>jQuery Selector</title>
    <link href="../Styles/Site.css" rel="stylesheet" type="text/css" />
    <style>
        div,span  
        {
            width:100px; 
            height:40px; 
            float:left; 
            padding:10px; 
            margin:10px; 
            background-color:#EEEEEE; 
        }
    </style>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            //id=content, div 요소를 찾아 테두리를 "blue"로 변경합니다.
            $("#content, div").css("border", "2px solid blue");
        });
    </script>
</head>
<body style="padding:10px;">
    <h2>jQuery 시작 Selector</h2>
    <p id="content">jQuery에 대한 자세한 내용을 보려면 jquery.com 을 방문하세요.</p>        
    <span class="myClass">SPAN class="myClass"</span>
    <div>DIV</div>    
    <span>SPAN</span>
    <div class="myClass">DIV class="myClass"</div>
</body>
</html>

 

03_007.jpg

 

 

두 번째 예제 : DIV 요소중에 클래스명이 myClass인 요소를 찾아 테두리를 파랑색으로 변경합니다.

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>jQuery Selector</title>
    <link href="../Styles/Site.css" rel="stylesheet" type="text/css" />
    <style>
        div,span  
        {
            width:100px; 
            height:40px; 
            float:left; 
            padding:10px; 
            margin:10px; 
            background-color:#EEEEEE; 
        }
    </style>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            //div 요소 중 class가 myclass인 개체를 찾아 테두리를 "blue"로 변경합니다.
            $("div.myClass").css("border", "2px solid blue");
        });
    </script>
</head>
<body style="padding:10px;">
    <h2>jQuery 시작 Selector</h2>
    <p id="content">jQuery에 대한 자세한 내용을 보려면 jquery.com 을 방문하세요.</p>        
    <span class="myClass">SPAN class="myClass"</span>
    <div>DIV</div>    
    <span>SPAN</span>
    <div class="myClass">DIV class="myClass"</div>
</body>
</html>

 

03_008.jpg

 

 

|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
12년 전 조회 6,644
12년 전 조회 2,487
12년 전 조회 693
12년 전 조회 651
12년 전 조회 1,401
12년 전 조회 2,043
12년 전 조회 884
12년 전 조회 692
12년 전 조회 1,322
12년 전 조회 1,455
12년 전 조회 685
12년 전 조회 1,114
12년 전 조회 1,387
12년 전 조회 776
12년 전 조회 1,066
12년 전 조회 3,659
12년 전 조회 1,408
12년 전 조회 950
12년 전 조회 832
12년 전 조회 1,200
12년 전 조회 1,436
12년 전 조회 4,230
12년 전 조회 5,558
12년 전 조회 683
12년 전 조회 2,257
12년 전 조회 6,723
12년 전 조회 2,397
12년 전 조회 9,316
12년 전 조회 519
12년 전 조회 720
12년 전 조회 1,342
12년 전 조회 1,657
12년 전 조회 1,310
12년 전 조회 1,920
12년 전 조회 2,332
12년 전 조회 3,186
12년 전 조회 2,155
12년 전 조회 2,326
12년 전 조회 2,301
12년 전 조회 1,583
12년 전 조회 1,381
12년 전 조회 1,026
12년 전 조회 1,215
12년 전 조회 2,000
12년 전 조회 1,556
12년 전 조회 1,261
12년 전 조회 2,300
12년 전 조회 2,035
12년 전 조회 1,877
12년 전 조회 1,614
12년 전 조회 2,313
12년 전 조회 1,130
12년 전 조회 777
12년 전 조회 392
12년 전 조회 534
12년 전 조회 1,042
12년 전 조회 2,458
12년 전 조회 2,472
12년 전 조회 1,555
12년 전 조회 1,174
12년 전 조회 959
12년 전 조회 9,081
12년 전 조회 588
12년 전 조회 1,559
12년 전 조회 1,141
12년 전 조회 1,604
12년 전 조회 1,801
12년 전 조회 992
12년 전 조회 1,567
12년 전 조회 2,203
12년 전 조회 1,333
12년 전 조회 1,280
12년 전 조회 1,179
12년 전 조회 7,410
12년 전 조회 1,310
12년 전 조회 1,175
12년 전 조회 1,953
12년 전 조회 952
12년 전 조회 1,477
12년 전 조회 1,089
12년 전 조회 1,036
12년 전 조회 2,813
12년 전 조회 1.1만
12년 전 조회 2,980
12년 전 조회 2,826
12년 전 조회 1,367
12년 전 조회 2,725
12년 전 조회 822
12년 전 조회 1,726
12년 전 조회 1,134
12년 전 조회 1,458
12년 전 조회 1,183
12년 전 조회 1,478
12년 전 조회 3,594
12년 전 조회 1,859
12년 전 조회 899
12년 전 조회 5,223
12년 전 조회 1,183
12년 전 조회 1,187
12년 전 조회 3,363
🐛 버그신고