data.text html,Convert HTML to data:text/html link using JavaScript

柴晔
2023-12-01

Characteristics of a data-URI

A data-URI with MIME-type text/html has to be in one of these formats:

data:text/html,

data:text/html;charset=UTF-8,

Base-64 encoding is not necessary. If your code contains non-ASCII characters, such as éé, charset=UTF-8 has to be added.

The following characters have to be escaped:

# - Firefox and Opera interpret this character as the marker of a hash (as in location.hash).

% - This character is used to escape characters. Escape this character to make sure that no side effects occur.

Additionally, if you want to embed the code in an anchor tag, the following characters should also be escaped:

" and/or ' - Quotes mark the value of the attribute.

& - The ampersand is used to mark HTML entities.

< and > do not have to be escaped inside a HTML attribute. However, if you're going to embed the link in the HTML, these should also be escaped (%3C and %3E)

JavaScript implementation

If you don't mind the size of the data-URI, the easiest method to do so is using encodeURIComponent:

var html = document.getElementById("html").innerHTML;

var dataURI = 'data:text/html,' + encodeURIComponent(html);

If size matters, you'd better strip out all consecutive white-space (this can safely be done, unless the HTML contains a

element/style). Then, only replace the significant characters:

var html = document.getElementById("html").innerHTML;

html = html.replace(/\s{2,}/g, '') //

.replace(/%/g, '%25') //

.replace(/&/g, '%26') //

.replace(/#/g, '%23') //

.replace(/"/g, '%22') //

.replace(/'/g, '%27'); //

var dataURI = 'data:text/html;charset=UTF-8,' + html;

 类似资料:

相关阅读

相关文章

相关问答