HTML Encode Methods (v68)

Revision 68 of this benchmark created on


Preparation HTML

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script>
var _reQuotes = /(['"])/g;
var _quotesEntities = {
    "'" : '&apos;',
    '"' : '&quot;'
};
var _reQuot = /"/g
var _reApos = /'/g
</script>

Setup

var html = document.body.innerHTML;
  var map = {
    "&": "&amp;",
    "'": "&#39;",
    '"': "&quot;",
    "<": "&lt;",
    ">": "&gt;"
  };
  var tempElement = $(document.createElement("div"));

Test runner

Ready to run.

Testing in
TestOps/sec
.innerHTML
return document.createElement('div').appendChild(document.createTextNode(html)).parentNode.innerHTML;
ready
jQuery .html()
return $('<div/>').text(html).html();
ready
.replace()
return html.replace(/&/g, '&amp;')
  .replace(/"/g, '&quot;')
  .replace(/'/g, '&#39;')
  .replace(/</g, '&lt;')
  .replace(/>/g, '&gt;');
ready
span
var s = document.createElement('span');
s.textContent = html;
return s.innerHTML;
ready
.innerHTML with replaces
return document.createElement('div').appendChild(document.createTextNode(html)).parentNode.innerHTML.replace(_reQuot, '&quot;').replace(_reApos, '&#39;');
ready
.innerHTML with parametric replace
return document.createElement('div').appendChild(document.createTextNode(html)).parentNode.innerHTML.replace(_reQuotes, function(substr, $1) {return _quotesEntities[$1] || $1;});
ready

Revisions

You can edit these tests or add more tests to this page by appending /edit to the URL.