首页 > web前端 > js教程 > 正文

如何从 HTML 字符串创建 DOM 元素(多种方法)

WBOY
发布: 2024-08-02 09:58:31
转载
850人浏览过

当我们需要创建简单的动态 html dom 元素时,我们可以使用 html 字符串模板。在 javascript 中有很多不同的方法可以实现这一点,但我们可能有一些考虑。


内部html

如何从 HTML 字符串创建 DOM 元素(多种方法)

const container = document.createelement('div');
container.innerhtml = `<div>hello world</div>`;
const node = container.firstelementchild;
登录后复制

这是最常见的方法之一。将html字符串插入到容器元素的innerhtml中,然后访问生成的dom节点。

但是,它只能处理有效的 html 节点,即标准 html 结构中合法的元素。例如,如果您尝试将 <tr> 元素插入 <div>,则不会创建该节点。

如何从 HTML 字符串创建 DOM 元素(多种方法)

此外,该方法不会执行html字符串中的任何脚本,这在处理不受信任的内容时更安全。

立即学习前端免费学习笔记(深入)”;

innerhtml + 模板元素

如何从 HTML 字符串创建 DOM 元素(多种方法)

const template = document.createelement('template');
template.innerhtml = `<div>hello world</div>`;
const node = template.content.firstelementchild;
登录后复制

使用 <template> 标签的优点是没有内容限制,可以包含任何类型的 html 结构,包括 <tr> 和 <td> 等与表格相关的元素。

如何从 HTML 字符串创建 DOM 元素(多种方法)

插入相邻html

如何从 HTML 字符串创建 DOM 元素(多种方法)

const container = document.createelement("div");
container.insertadjacenthtml("afterbegin", `<div>hello world</div>`);
const node = container.firstelementchild;
登录后复制

该方法与innerhtml类似,只能处理有效的html节点。它也不会执行脚本。

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

腾讯元宝 223
查看详情 腾讯元宝

dom解析器

如何从 HTML 字符串创建 DOM 元素(多种方法)

const node = new domparser().parsefromstring(`<div>hello world</div>`, "text/html").body.firstelementchild;
登录后复制

该方法通过创建完整的 html 文档来解析字符串,然后从文档中提取节点。这意味着它比其他解决方案相对慢,不建议使用。

它只能处理有效的 html 节点,不会执行脚本。

range.createcontextualfragment

如何从 HTML 字符串创建 DOM 元素(多种方法)

const node = document.createRange().createContextualFragment(`<div>Hello World</div>`).firstElementChild;

登录后复制

这个方法可能是最简单的。默认情况下它也只能处理有效的 html 节点。但是,我们可以设置上下文来避免这种情况。

如何从 HTML 字符串创建 DOM 元素(多种方法)

请注意,它会执行 html 字符串中的脚本,因此在处理不受信任的内容时要特别小心,例如使用 dompurify 等清理器。

如何从 HTML 字符串创建 DOM 元素(多种方法)

结论

针对不同的情况,您可能需要选择最适合您的方法。

如果您觉得我的内容有帮助,请考虑订阅。我每天发送一份时事通讯,其中包含最新的网络开发更新。感谢您的支持!

以上就是如何从 HTML 字符串创建 DOM 元素(多种方法)的详细内容,更多请关注php中文网其它相关文章!

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号