首页  >  问答  >  正文

JavaScript 中的 ReplaceAll() 未能在 HTML 页面中找到 </em>

我不熟悉 JavaScript 和 html。但我尝试使用 JavaScript 实现一个函数。

我想替换html页面中的所有<em></em>。于是我在页面中插入一段javascript代码:

function rep() 
{
    document.body.innerHTML
        = document.body.innerHTML
        .replaceAll("<em>", "_");
    document.body.innerHTML
        = document.body.innerHTML
        .replaceAll("</em>", "_");

}
window.onload=rep()
<!DOCTYPE html>
<html lang="en">
<!-- ... -->
<article>
    <div class="container">
        <div class="row">
            <div class="col-lg-8 col-lg-offset-2 col-md-10 col-md-offset-1 post-container">

                <p>(Weierstrass) 设 $z_{0}$ 是 $f$ 的本性奇点,那么对任意 $A \in \mathbb{C}<em>{\infty}$, 必存在趋于 $z</em>{0}$ 的点列 $\left{z_{n}\right}$, 使得 $\lim <em>{n \rightarrow \infty} f\left(z</em>{n}\right)=A$.</p>

            </div>
        </div>
    </div>
<!-- ... -->

</html>

成功将<em>替换为“_”,但所有</em>都没有改变。代码有什么问题吗? 谢谢!

P粉323224129P粉323224129224 天前373

全部回复(1)我来回复

  • P粉926174288

    P粉9261742882024-03-31 12:56:14

    让我们看看当浏览器看到无效的 html 时会发生什么,例如:

    test

    console.log(document.body.innerHTML)
    test

    上面打印 test (和脚本)

    这是因为浏览器在解析时去掉了无效的结构

    当你这样做时

    document.body.innerHTML
      = document.body.innerHTML
      .replaceAll("", "_");

    您正确替换了所有 <em> 标签,但结束标签被删除

    另一方面,这也将起作用:

    document.body.innerHTML = document.body.innerHTML
      .replaceAll("", "_")
      .replaceAll("", "_");
    test

    回复
    0
  • 取消回复