Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>JS Bin</title>
</head>
<body>
  Test message :/
  <p>Other :/ text :)</p>
  <span>This too <a href="http://example.com">Example.com</a> :/</span>
</body>
</html>
 
var smiles = {
  ":)": "",
  ":/": "",
};
var replacements = [];
onEachTextNode(document.body, function(node) {
  var newNode = replaceTokensWithImages(node, smiles);
  replacements.push([node, newNode]);
});
replacements.forEach(function(replacement) {
  var node, newNode;
  node = replacement[0];
  newNode = replacement[1];
  
  node.parentNode.replaceChild(newNode, node);
});
function onEachTextNode(base, cb) {
  var iterator =
      document.createNodeIterator(base, NodeFilter.SHOW_TEXT, nonEmptyText);
  
  var currentNode = iterator.nextNode();
  
  while(currentNode !== null) {
    cb(currentNode);
    currentNode = iterator.nextNode();
  }
  function nonEmptyText(node) {
    return node.textContent.search(/\S/) !== -1 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT;
  }
}
function replaceTokensWithImages(textNode, map) {
  var fragment = document.createDocumentFragment();
  fragment.appendChild(textNode.cloneNode(true));
  
  return Object.keys(map).reduce(function(node, token) {
    return replaceTokenWithImage(node, token, map[token]);
  }, fragment);
}
function replaceTokenWithImage(fragment, token, imageUrl) {
  var newFragment = document.createDocumentFragment();
  
  [].forEach.call(fragment.childNodes, function(node) {
    if(node.nodeType !== document.TEXT_NODE) {
      newFragment.appendChild(node.cloneNode(true));
      return;
    }
    var text = node.textContent;
    var sections = text.split(token);
 
    var current, hasNext;
    for(var i = 0; i < sections.length; i++) {
      current = sections[i];
      hasNext = (i + 1) in sections;
    
      newFragment.appendChild(new Text(current));
    
      if(hasNext) {
        newFragment.appendChild(createImage());
      }
    }
  });
  
  return newFragment;
  
  function createImage() {
    var image = new Image();
    image.src = imageUrl;
    image.alt = token;
    return image;
  }
}
Output

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
anonymouspro
0viewers