JS 转换 HTML 结构?

现在有一个这样的列表

<ul id="root">
  <li>
    123
    <ul>
        <li>
            123-1
        </li>
        <li>
            123-2
            <ul>
                <li>
                    123-2-1
                </li>
                <li>
                    123-2-2
                </li>
                <li>
                    123-2-3
                </li>
            </ul>
        </li>
        <li>
            123-3
        </li>
    </ul>
  </li>
</ul>

需要使用js或jquery, 转成如下结构

<ul id="root">
  <li>
    <a>123</a>
    <ul>
        <li>
            <a>123-1</a>
        </li>
        <li>
            <a>123-2</a>
            <ul>
                <li>
                    <a>123-2-1</a>
                </li>
                <li>
                    <a>123-2-2</a>
                </li>
                <li>
                    <a>123-2-3</a>
                </li>
            </ul>
        </li>
        <li>
            <a>123-3</a>
        </li>
    </ul>
  </li>
</ul>
阅读 1.9k
2 个回答

原生 JS 写了一段,只要将文本节点找到,使用 replaceChild() 替换为 <a> 即可。

const root = document.querySelector("#root");
const dfs = (root) => {
    // 扫描元素下所有的子节点
    for (const node of root.childNodes) {
        // 确定子节点为文本节点类型,且内容不为空
        if (node.nodeType === 3 && node.textContent.trim().length !== 0) {
            // 创建标签,接受内容,并替换节点
            const a = document.createElement("a");
            a.href = "#";
            a.text = node.textContent.trim();
            root.replaceChild(a, node)
        } else {
            // 非文本节点,递归替换
            dfs(node);
        }
    }
};
dfs(root);

temp2 就是每一个 #text 文本节点。可以 childNodes

el=document.createElement('a')
temp2.replaceWith(el)
el.appendChild(temp2)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏