gpt4 book ai didi

javascript - 给innerHTML赋值会不会异常?

转载 作者:搜寻专家 更新时间:2023-11-01 04:28:39 27 4
gpt4 key购买 nike

我通读了https://developer.mozilla.org/en-US/docs/Web/API/Element/innerHTML ,它声称 SyntaxError可能会发生。

dom = document.createElement('div')
// output: <div></div>
dom.innerHTML = '[try.various.strings.here]'
// output: "[try.various.strings.here]"
dom
// check final DOM

我尝试用 <div> 替换测试字符串(部分),<div (坏了)和<div></p> (无与伦比)。我从来没有遇到过异常(exception)。我想知道是否需要为其添加预检查或保护 ( try..catch )。

最佳答案

长话短说

规范说如果浏览器需要它可以,但我不认为任何主流浏览器都这样做HTML(好吧,我不会对 IE9-IE11 和实际上是某些元素类型)。 (而它们对 XML 。)来自 HTML 5.2 specification 中 HTML 解析器的定义。 :

This specification defines the parsing rules for HTML documents, whether they are syntactically correct or not. Certain points in the parsing algorithm are said to be parse errors. The error handling for parse errors is well-defined (that’s the processing rules described throughout this specification), but user agents, while parsing an HTML document, may abort the parser at the first parse error that they encounter for which they do not wish to apply the rules described in this specification.

(我的重点)

详情

DOM Parsing and Serialization spec定义 innerHTML,并说:

On setting, these steps must be run:

  1. Let fragment be the result of invoking the fragment parsing algorithm with the new value as markup, and the context object as the context element.
  2. If the context object is a template element, then let context object be the template's template contents (a DocumentFragment).
  3. Replace all with fragment within the context object.

如果我们点击片段解析算法链接,我们可以:

The following steps form the fragment parsing algorithm, whose arguments are a markup string and a context element:

  1. If the context element's node document is an HTML document: let algorithm be the HTML fragment parsing algorithm.
    If the context element's node document is an XML document: let algorithm be the XML fragment parsing algorithm.
  2. Let new children be the result of invoking algorithm with markup as the input, and context element as the context element.
  3. Let fragment be a new DocumentFragment whose node document is context element's node document.
  4. Append each Node in new children to fragment (in tree order).
  5. Return the value of fragment.

如果我们遵循上面的HTML 解析算法 链接,我们将获得创建和使用 HTML 解析器的步骤。如果我们点击指向 HTML 解析器定义的链接,我们将获得上面 TL;DR 中的第一个链接和上面引用的文本。

关于javascript - 给innerHTML赋值会不会异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50922305/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com