테스트 사이트 - 개발 중인 베타 버전입니다

상위요소 찾기 노드

· 3년 전 · 2091 · 3

 

순수 자바스크립트로 상위요소 찾는 코드입니다.

jquery로 하면 쉽게할 수 있지만 그렇지 못한 환경에서는

이러한 코드가 필요할 수 있습니다.

그래서 소스코드 공유합니다.

 

[code]

<html>

<head>

 

</head>

 

<body>

 

<div class="parent_node">

    <div id="my_elm">test</div>

</div>



 

<script>

function collectionHas(a, b) { //helper function (see below)

    for(var i = 0, len = a.length; i < len; i ++) {

        if(a[i] == b) return true;

    }

    return false;

}

 

function findParentBySelector(elm, selector) {

    var all = document.querySelectorAll(selector);

    var cur = elm.parentNode;

    while(cur && !collectionHas(all, cur)) { //keep going up until you find a match

        cur = cur.parentNode; //go up

    }

    return cur; //will return null if not found

}

 

var my_elm = document.getElementById("my_elm"); //

var selector = ".parent_node";

var parent = findParentBySelector(my_elm, selector);

 

console.log(parent);

</script>

</body>



 

</html>

[/code]

댓글 작성

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

로그인하기

댓글 3개

3년 전
감사합니다~~~
감사합니다 :)
감사합니다

게시글 목록

번호 제목
17316
17315
17313
17312
17305
17304
17298
17294
17291
17285
17284
17279
17272
17271
17270
17262
17255
17248
17241
17238
17236
17220
17217
JavaScript 회원가입 2
17216
17214
17207
17205
17203
17201
17198