j

jQuery Traverse - Miscellaneous Traversing

· 12년 전 · 1070

탐색 메서드 두 번째 시간으로 이번에는 Miscellaneous 메서드에 대해 알아 보도록 하겠습니다.

우선 Miscellaneous 메서드의 종류를 정리하면 다음과 같습니다.

 메서드

 메서드 설명

 .add()

 일치하는 요소의 집합에 요소를 추가합니다.

 .andSelf()

 현재 설정 스택에 요소의 이전 설정을 추가합니다.

 .contents()

 텍스트 및 주석 노드를 포함 일치하는 요소 집합의 자식 집합을 반환합니다. 

 .end()

 이전 상태로 일치하는 집합을 반환합니다.

표 1. [jQuery Miscellaneous 메서드 종류]

 

Miscellaneous의 뜻을 사전에서 찾아 보면 ‘여러 가지 종류의, 이것저것 다양한’ 이란 뜻을 가지고 있습니다. 아마도 해당 메서드의 성격이 너무나도 달라서 카테고리의 이름을 이렇게 잡은 듯 합니다. 


add()

이름에서도 쉽게 알 수 있듯이 뭔가를 더하는 역할을 하는 메서드로 다음과 같이 사용을 합니다.


.add(selector)

.add(elements)

.add(html)


셀렉터를 통해 선택한 개체에 ()안에 값을 더하는 메서드로 selector를 통해 가져온 개체, span과 같은 요소, <span>testSpan</span>과 같은 html 요소가 올 수 있습니다.

<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,pre { background : #FFF; padding:10px; margin:10px; }
        table { border:1px solid #AAA; }
        td { border:1px solid #AAA; width:25px; height:25px; }
    </style>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
        $(document).ready(function() {
            $("li").add("div > p").css("border", "1px solid red");            
        });
    </script>
</head>
<body style="padding:10px;">
    <h2>jQuery 시작 Selector</h2>
    <p>jQuery에 대한 자세한 내용을 보려면 jquery.com 을 방문하세요.</p>
    <div>
        <ul>
            <li>list item 1</li>
            <li>list item 2</li>
            <li>list item 3</li>
            <li>list item 4</li>
        </ul>
        <p>this is P</p>
    </div>
</body>
</html>

10_mod_01.jpg


 

.andSelf()

사용빈도가 상당히 낮을 것으로 추측을 하는 메서드로 저 또한 이번 강좌를 준비하면서 알게 된 메서드입니다. 앞서 설명한 부분을 다시 보면 “현재 설정 스택에 요소의 이전 설정을 추가합니다.” 말이 좀 어렵습니다. 


우선 jQuery 문서에 있는 예제를 살펴 보기로 하겠습니다.

<!DOCTYPE html>
<html>
    <head>
    <style>
        p, div { margin:5px; padding:5px; }
        .border { border: 2px solid red; }
        .background { background:yellow; }
    </style>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    </head>
    <body>
        <div>
            <p>First Paragraph</p>
            <p>Second Paragraph</p>
        </div>
    <script>
    $("div").find("p").andSelf().addClass("border");
    $("div").find("p").addClass("background");
    </script>
</body>
</html>


07_007(2).jpg


다음 그림을 보면 좀더 이해가 쉽습니다.


07_008.jpg




.contents()

셀렉터를 통해 선택된 개체 안에 있는 모든 요소를 반환합니다.

단어의 뜻대로 선택된 개체 안에 있는 요소의 집합을 반환하며, 이 메서드의 경우 filter 메서드와 조합을 통해 많이 사용을 하고 있습니다. 


다음 예제를 통해 간단한 사용법을 살펴 보도록 하겠습니다.

<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,pre { background : #FFF; padding:10px; margin:10px; }
        table { border:1px solid #AAA; }
        td { border:1px solid #AAA; width:25px; height:25px; }
    </style>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $("ul").find("li").contents().remove("ul");
        });
    </script>
</head>
<body style="padding:10px;">
    <h2>jQuery 시작 Selector</h2>
    <p>jQuery에 대한 자세한 내용을 보려면 jquery.com 을 방문하세요.</p>
    <div>
        <ul>
            <li>list item 1</li>
            <li>list item 2
                <ul>
                    <li>sub item 1</li>
                    <li>sub item 2</li>
                </ul>
            </li>                
            <li>list item 3</li>
            <li>list item 4</li>
        </ul>
    </div>
</body>
</html>


07_007(3).jpg

[메서드 적용전의 모습]


07_007(4).jpg

[메서드 적용 후의 모습]


remove(selector) 메서드는 "selector"와 일치하는 내용을 삭제합니다.
예제를 간단히 설명하면, 셀렉터를 통해 ul 요소를 찾은 후 find()를 통해 "li" 요소를 찾습니다. 마지막으로 contents() 메서드를 통해 li 요소에 담겨있는 모든 요소를 찾은 후 remove() 메서드를 통해 "ul"이 제거가 되었습니다.




.end()

이 메서드는 정말 중요하고 많은 곳에서 사용이 되며, 실제로 복잡한 스크립트를 작성할 때 마법과 같은 역할을 해 주는 메서드입니다.

.end() 메서드를 간단히 설명 드리자면 .end() 메서드가 호출 후 바로 이전의 상태로 돌아가는 것을 의미합니다. 


역시나 설명이 어렵우시나요 ?


$(div).find(p).end().addClass(“myClass”);와 같은 구문이 있다고 한다면 myClass라는 class 속성이 div에 적용이 됩니다. 

.end() 메서드가 없다면 “div” 요소 안에 있는 “p” 요소에 class 속성이 적용이 되지만 .end() 메서드의 호출로 인해 “p” 요소 이전의 개체인 $(“div”) 개체가 다시 호출이 되고 호출된 $(“div)에 class 속성이 적용이 되는 것입니다.


그림으로 다시 설명을 드리자면 아래와 같이 동작을 한다고 보시면 됩니다.

07_012.jpg 


.end() 메서드의 경우 앞에 강좌에서 설명한 jQuery의 특징 중에 플러그인과 메서드체인을 이용한 스크립트 작성에 빠질 수 없는 요소로 정확히 이해를 하신다면 간결하고 클라이언트에 부담 확~ 줄일 수 있는 프로그래밍이 가능하므로 해당 메서드에 대해 정확히 이해를 하시기 바랍니다.

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

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
12년 전 조회 1,498
12년 전 조회 850
12년 전 조회 1,864
12년 전 조회 968
12년 전 조회 1,539
12년 전 조회 2,812
12년 전 조회 2,375
12년 전 조회 1,721
12년 전 조회 6,701
12년 전 조회 2,534
12년 전 조회 740
12년 전 조회 702
12년 전 조회 1,447
12년 전 조회 2,090
12년 전 조회 929
12년 전 조회 735
12년 전 조회 1,377
12년 전 조회 1,512
12년 전 조회 736
12년 전 조회 1,165
12년 전 조회 1,439
12년 전 조회 828
12년 전 조회 1,119
12년 전 조회 3,706
12년 전 조회 1,456
12년 전 조회 991
12년 전 조회 886
12년 전 조회 1,254
12년 전 조회 1,485
12년 전 조회 4,280
12년 전 조회 5,605
12년 전 조회 743
12년 전 조회 2,301
12년 전 조회 6,780
12년 전 조회 2,444
12년 전 조회 9,373
12년 전 조회 572
12년 전 조회 769
12년 전 조회 1,393
12년 전 조회 1,700
12년 전 조회 1,358
12년 전 조회 1,967
12년 전 조회 2,383
12년 전 조회 3,232
12년 전 조회 2,196
12년 전 조회 2,375
12년 전 조회 2,351
12년 전 조회 1,628
12년 전 조회 1,430
12년 전 조회 1,071
12년 전 조회 1,265
12년 전 조회 2,047
12년 전 조회 1,606
12년 전 조회 1,310
12년 전 조회 2,354
12년 전 조회 2,074
12년 전 조회 1,920
12년 전 조회 1,661
12년 전 조회 2,354
12년 전 조회 1,171
12년 전 조회 815
12년 전 조회 438
12년 전 조회 578
12년 전 조회 1,086
12년 전 조회 2,506
12년 전 조회 2,510
12년 전 조회 1,593
12년 전 조회 1,211
12년 전 조회 999
12년 전 조회 9,126
12년 전 조회 633
12년 전 조회 1,594
12년 전 조회 1,190
12년 전 조회 1,636
12년 전 조회 1,844
12년 전 조회 1,029
12년 전 조회 1,608
12년 전 조회 2,245
12년 전 조회 1,374
12년 전 조회 1,318
12년 전 조회 1,225
12년 전 조회 7,459
12년 전 조회 1,357
12년 전 조회 1,216
12년 전 조회 2,001
12년 전 조회 1,001
12년 전 조회 1,520
12년 전 조회 1,130
12년 전 조회 1,080
12년 전 조회 2,859
12년 전 조회 1.1만
12년 전 조회 3,014
12년 전 조회 2,866
12년 전 조회 1,412
12년 전 조회 2,760
12년 전 조회 862
12년 전 조회 1,765
12년 전 조회 1,172
12년 전 조회 1,498
12년 전 조회 1,225
🐛 버그신고