vlambda博客
学习文章列表

快速创建HTML文档的三种方法

// 每日前端夜话 第532 篇
// 正文共:1200 字
// 预计阅读时间:5 分钟

有时我们需要即时动态的创建 HTML 文档,无论是目标页,还是显示确定的页面,或者是包含整个页面的 iframe,如果文档足够简单,则可以轻松地将其放在一起并与 data URL 或 JavaScript 配合使用。

你肯定已经知道如何用 JavaScript 将 HTML 添加到文档中,但是要想创建一个完整的 HTML 文档该怎么做呢?下面提供了三种方法,甚至不需要 JavaScript。

快速创建HTML文档的三种方法 交易担保 前端面试星球 每天刷一刷,面试顶呱呱

我将在 iframes 中渲染新创建的文档,以便你可以看到它们的渲染结果。你可以直接使用这些文件,也可以把它们保存到数据库或不同的 Web 服务服务器中在其他地方渲染。

1. Data URL

Data URLs 为在网页上添加文档提供了一个简单有效的方法。

Data URL 以 data: 开始,后面是“URL方案”,也就是要提供的内容,同时你可以设置文件类型和内容的编码。

你可以看到下面这种方式的图像,其中 base64 编码形式的字符串作为内容给出。

<img src=""
alt="man with a computer">

上面的代码显示下面这张 PNG 图片。

快速创建HTML文档的三种方法
Base64 图片

同样,data URL也可以支持 HTML 文档:

<iframe src='data:text/html,<strong>Hello World!</strong>'></iframe>

iframe 能够渲染以 text/html 媒体类型及 HTML 代码为内容的 data URL。

完整代码:

<h4>用 Data URL 创建 HTML 文档</h4>
<iframe src='data:text/html,<strong>Hello World!</strong>'></iframe>

2. Domimplingation接口

DOMImplementation是一个界面,可以用它的 createDocument() (用于XML)或createHTMLDocument() 方法来创建新的文档。通过 document.implementation 对象可以访问该接口。

createHTMLDocument()  方法有一个用来设置新文档标题的可选参数。

可以通过 append()appendChild() 等方法将 HTML 添加到新创建的文档:

<iframe src=""></iframe>
window.onload = () => {
  var doc = document.implementation.createHTMLDocument();
  doc.body.append('Hello World!');
  var iframeDoc = document.querySelector('iframe').contentDocument;
  iframeDoc.replaceChild(
  doc.documentElement,
  iframeDoc.documentElement
  );
}

在上面的代码中,用 Domimpling 接口的  comperehtmldocument() 方法创建新的HTML文档,并把字符串 Hello World 添加到其 body 元素中。

然后就是渲染新创建的文档,代码中用了  replaceChild() 替换了 iframe(ifRamedoc.documentElement)的文档元素。这样就能看到我们添加文档中的字符串 Hello World! 了 。

3. DOMParser API

顾名思义,domparser api 用于将 HTML或XML字符串解析为 DOM。

可以用它的构造函数 domparser() 创建新的 domparser 对象实例。实例包含一个名为  parseFromString()  的方法,它又两个参数:要解析的字符串以及要创建的文档类型。

<iframe src=""></iframe>
window.onload = () => {
  var parser = new DOMParser();
  var doc = parser.parseFromString('<strong>Hello World! </strong>'"text/html");
  doc.body.append('extra text');
  var iframeDoc = document.querySelector('iframe').contentDocument;
  iframeDoc.replaceChild(doc.documentElement, iframeDoc.documentElement);
}

在上面的代码中,使用 parseFromString()  方法创建了新的 DOMParser 实例,用于将 HTML 字符串解析为 DOM 文档。

然后用和上一个代码段相同的方式,新创建的文档元素换了 iframe 的文档元素。因此我们创建的文档中的 HTML 代码在 iframe 中可见。



强力推荐前端面试刷题神器
快速创建HTML文档的三种方法

精彩文章回顾,点击直达