element.insertAdjacentHTML - Web API 接口参考 编辑
insertAdjacentHTML()
方法将指定的文本解析为 Element
元素,并将结果节点插入到DOM树中的指定位置。它不会重新解析它正在使用的元素,因此它不会破坏元素内的现有元素。这避免了额外的序列化步骤,使其比直接使用innerHTML操作更快。
语法
element.insertAdjacentHTML(position, text);
position
- 一个
DOMString
,表示插入内容相对于元素的位置,并且必须是以下字符串之一:'beforebegin'
:元素自身的前面。'afterbegin'
:插入元素内部的第一个子节点之前。'beforeend'
:插入元素内部的最后一个子节点之后。'afterend'
:元素自身的后面。
text
- 是要被解析为HTML或XML元素,并插入到DOM树中的
DOMString
。
位置名称的可视化
<!--注意: beforebegin和afterend位置,仅在节点在树中且节点具有一个parent元素时工作。beforebegin
--><p>
<!--afterbegin
--> foo <!--beforeend
--></p>
<!--afterend
-->
示例
// 原为 <div id="one">one</div>
var d1 = document.getElementById('one');
d1.insertAdjacentHTML('afterend', '<div id="two">two</div>');
// 此时,新结构变成:
// <div id="one">one</div><div id="two">two</div>
注意
安全问题
使用 insertAdjacentHTML
插入用户输入的HTML内容的时候,需要转义之后才能使用。
如果只是为了插入文本内容(而不是HTML节点),不建议使用这个方法,建议使用node.textContent
或者 node.insertAdjacentText()
。因为这样不需要经过HTML解释器的转换,性能会好一点。
规范
Specification | Status | Comment |
---|---|---|
DOM Parsing and Serialization Element.insertAdjacentHTML() | Working Draft |
浏览器兼容性
BCD tables only load in the browser
此页上的兼容性表是从结构化数据生成的。如果您想贡献数据,请访问 https://github.com/mdn/browser-compat-data 并向我们发送一个请求。相关链接
- 包括Henri Sivonen 在内的某些 hacks.mozilla.org 客座文章 显示,
insertAdjacentHTML
在某些情况下可以更快。 Element.insertAdjacentElement()
Element.insertAdjacentText()
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论