js递归检索包含子串的所有文本节点

AI 概述
检索方法性能测试包含特定子串的文本节点检索结论与最佳实践 在Web 前端开发过程中,高效地检索文本节点对于实现一些功能,如关键词高亮,显得尤为重要,特别是在处理页面动态加载内容的情况下。本文将详细探讨几种方法,用于检索 HTML 元素的所有子文本节点,并通过性能测试来确定最佳解决方案。 ...
目录
文章目录隐藏
  1. 检索方法概述
  2. 性能测试
  3. 包含特定子串的文本节点检索
  4. 结论与最佳实践

Web 前端开发过程中,高效地检索文本节点对于实现一些功能,如关键词高亮,显得尤为重要,特别是在处理页面动态加载内容的情况下。本文将详细探讨几种方法,用于检索 HTML 元素的所有子文本节点,并通过性能测试来确定最佳解决方案。

检索方法概述

  1. 使用 childNodes 递归
  2. TreeWalker
  3. NodeIterator
  4. document.evaluate()配合 XPath

性能测试

测试代码基于一个由多个流行网站 HTML 代码组合而成的样本文档。以下是几种主要的检索方法实现:

// childNodes 递归
function recursiveChildNodes(el) {
    var nodes = [];
    function traverse(el) {
        for (var i = 0; i < el.childNodes.length; i++) {
            var node = el.childNodes[i];
            if (node.nodeType == Node.TEXT_NODE) {
                nodes.push(node);
            } else traverse(node);
        }
    }
    traverse(el);
    return nodes;
}

// TreeWalker
function useTreeWalker(el) {
    const walker = document.createTreeWalker(el, NodeFilter.SHOW_TEXT);
    const nodes = [];
    while (walker.nextNode()) nodes.push(walker.currentNode);
    return nodes;
}

// NodeIterator
function useNodeIterator(el) {
    const iterator = document.createNodeIterator(el, NodeFilter.SHOW_TEXT);
    const nodes = [];
    let node;
    while (node = iterator.nextNode()) nodes.push(node);
    return nodes;
}

// XPath
function useXPath(el) {
    let iterator = document.evaluate("//text()", el, null, XPathResult.UNORDERED_NODE_ITERATOR_TYPE);
    const nodes = [];
    let node;
    while (node = iterator.iterateNext()) nodes.push(node);
    return nodes;
}

递归检索包含子串的所有文本节点

测试结果显示,TreeWalker、NodeIterator 和 XPath 方法的性能相近,均比基于 childNodes 的递归方法快约 5 倍。

包含特定子串的文本节点检索

对于需要查找包含特定子串的文本节点,比较了两种方法:

  1. 使用 TreeWalker 获取所有文本节点后过滤
  2. 直接使用 XPath 表达式查找包含特定字符串的文本节点
// TreeWalker + 过滤
function treeWalkerWithFilter(el, text) {
    const walker = document.createTreeWalker(el, NodeFilter.SHOW_TEXT);
    const nodes = [];
    while (walker.nextNode()) {
        if (walker.currentNode.nodeValue.includes(text)) {
            nodes.push(walker.currentNode);
        }
    }
    return nodes;
}

// XPath 直接查找
function xpathDirectSearch(el, text) {
    let iterator = document.evaluate(`//text()[contains(.,'${text}')]`, el, null, XPathResult.UNORDERED_NODE_ITERATOR_TYPE);
    const nodes = [];
    let node;
    while (node = iterator.iterateNext()) nodes.push(node);
    return nodes;
}

递归检索包含子串的所有文本节点

测试结果表明,使用 TreeWalker 获取所有节点后再过滤的方法比直接使用 XPath 条件查询更快。

结论与最佳实践

  1. 对于检索所有嵌套文本节点,document.createTreeWalker()和 document.createNodeIterator()是最佳选择。
  2. 当需要查找包含特定子串的文本节点时,先使用 TreeWalker 获取所有文本节点,然后进行过滤是更高效的方法。

在处理大型、复杂的 Web 应用时,实现高性能的文本搜索和高亮功能变得尤为重要。这些优化技巧在提升页面的响应速度和用户体验方面发挥着关键作用。通过选择合适的方法,能够显著提高网页的性能和用户体验。

以上关于js递归检索包含子串的所有文本节点的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。

「点点赞赏,手留余香」

1

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » js递归检索包含子串的所有文本节点

发表回复