>웹 프론트엔드 >JS 튜토리얼 >jQuery 또는 Pure JavaScript를 사용하여 요소 내에서 텍스트 노드를 효율적으로 선택하려면 어떻게 해야 합니까?

jQuery 또는 Pure JavaScript를 사용하여 요소 내에서 텍스트 노드를 효율적으로 선택하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-16 12:32:11796검색

How Can I Efficiently Select Text Nodes within an Element Using jQuery or Pure JavaScript?

jQuery로 텍스트 노드 선택

요소 내의 텍스트 노드를 선택하는 것은 jQuery에서 어려운 작업일 수 있습니다. 다행스럽게도 이를 달성하는 데 사용할 수 있는 다양한 접근 방식이 있습니다.

접근 방법 1: Contents() 및 Find() 결합

jQuery는 선택을 위한 전용 기능을 제공하지 않습니다. 텍스트 노드. 그러나 해결 방법은 텍스트 노드를 포함한 하위 노드를 검색하는 content() 메서드를 활용하고 이를 하위 요소를 선택하지만 텍스트 노드를 제외하는 find() 메서드와 결합하는 것입니다.

var getTextNodesIn = function(el) {
    return $(el).find(":not(iframe)").addBack().contents().filter(function() {
        return this.nodeType == 3;
    });
};

참고: jQuery 1.7 이전 버전의 경우 addBack()을 andSelf()로 바꾸고, 1.8 이상 버전의 경우 다음을 사용하세요. addBack().

접근 방식 2: 순수 DOM 솔루션

더 효율적인 솔루션을 선호하는 경우 jQuery가 아닌 방법을 사용할 수 있습니다. 여기에는 DOM 트리를 순회하는 재귀 함수가 포함됩니다.

function getTextNodesIn(node, includeWhitespaceNodes) {
    var textNodes = [], nonWhitespaceMatcher = /\S/;

    function getTextNodes(node) {
        if (node.nodeType == 3) {
            if (includeWhitespaceNodes || nonWhitespaceMatcher.test(node.nodeValue)) {
                textNodes.push(node);
            }
        } else {
            for (var i = 0, len = node.childNodes.length; i < len; ++i) {
                getTextNodes(node.childNodes[i]);
            }
        }
    }

    getTextNodes(node);
    return textNodes;
}

사용 예

두 접근 방식 모두 지정된 요소 내의 모든 텍스트 노드를 검색할 수 있습니다.

var textNodes = getTextNodesIn(el);

includeWhitespaceNodes 매개변수를 사용자 정의하여 공백 텍스트 노드 여부를 선택할 수 있습니다. 결과에 포함됩니다.

위 내용은 jQuery 또는 Pure JavaScript를 사용하여 요소 내에서 텍스트 노드를 효율적으로 선택하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.