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 중국어 웹사이트의 기타 관련 기사를 참조하세요!