Test name | Executions per second |
---|---|
Text node | 95.6 Ops/sec |
Option node | 155.6 Ops/sec |
Replace A | 736.0 Ops/sec |
Replace B | 76.1 Ops/sec |
Replace C | 45.1 Ops/sec |
window.htmlStr = `<div>
<input name="test" value="test" />
<img />
</div>`;
const escapeElement = document.createElement('span');
const escapeTextNode = document.createTextNode('');
escapeElement.append(escapeTextNode);
function escape(str) {
escapeTextNode.textContent = str;
return escapeElement.innerHTML;
}
let i = 0;
for (; i < 10000; i++) {
escape(htmlStr);
}
const option = new Option('');
function escape(str) {
option.label = str;
return option.label;
}
let i = 0;
for (; i < 10000; i++) {
escape(htmlStr);
}
function escape(str) {
const E = [
['&', '&'],
['<', '<'],
['>', '>'],
["'", '''],
['"', '"'],
];
return (v) => E.reduce((r, e) => str.replaceAll(e[0], e[1]), v);
}
let i = 0;
for (; i < 10000; i++) {
escape(htmlStr);
}
function escape(str) {
return str.replaceAll('&', '&')
.replaceAll('<', '<')
.replaceAll('>', '>')
.replaceAll("'", ''')
.replaceAll('"', '"');
return (v) => E.reduce((r, e) => str.replaceAll(e[0], e[1]), v);
}
let i = 0;
for (; i < 10000; i++) {
escape(htmlStr);
}
function escape(str) {
return ('' + str).replace(/[^\w. ]/gi, c => '&#' + c.charCodeAt(0) + ';')
}
let i = 0;
for (; i < 10000; i++) {
escape(htmlStr);
}