How to highlight search results with JavaScript and CSS
You see it in Google search results and a lot of other sites that have good search functionality. When you perform a search, your words or phrases are highlighted in the search results making it easy for you to find the most relevant content.
Today I’m going to show you a simple way to add this to your website or blog so your users can find what they need in style. I think that this kind of thing should be implemented more often for how easy it is to implement.
functionhighlightOnLoad(){// Get search stringif(/s\=/.test(window.location.search)){varsearchString=getSearchString();// Starting node, parent to all nodes you want to searchvartextContainerNode=document.getElementById("content");// Informational message for searchvarsearchInfo='Search Results for: ';// Split search terms on '|' and iterate over resulting arrayvarsearchTerms=searchString.split('|');for(variinsearchTerms){// The regex is the secret, it prevents text within tag declarations to be affectedvarregex=newRegExp(">([^<]*)?("+searchTerms[i]+")([^>]*)?<","ig");highlightTextNodes(textContainerNode,regex,i);// Add to info-stringsearchInfo+=' <span class="highlighted term'+i+'">'+searchTerms[i]+'</span> ';}// Create div describing the searchvarsearchTermDiv=document.createElement("H2");searchTermDiv.className='searchterms';searchTermDiv.innerHTML=searchInfo;// Insert as very first child in searched nodetextContainerNode.insertBefore(searchTermDiv,textContainerNode.childNodes[0]);}}// Pull the search string out of the URLfunctiongetSearchString(){// Return sanitized search string if it existsvarrawSearchString=window.location.search.replace(/[a-zA-Z0-9\?\&\=\%\#]+s\=(\w+)(\&.*)?/,"$1");// Replace '+' with '|' for regex// Also replace '%20' if your cms/blog uses this instead (credit to erlando for adding this)returnrawSearchString.replace(/\%20|\+/g,"\|");}functionhighlightTextNodes(element,regex,termid){vartempinnerHTML=element.innerHTML;// Do regex replace// Inject span with class of 'highlighted termX' for google style highlightingelement.innerHTML=tempinnerHTML.replace(regex,'>$1<span class="highlighted term'+termid+'">$2</span>$3<');}// Call this onload, I recommend using the function defined at: http://untruths.org/technology/javascript-windowonload/addOnLoad(highlightOnLoad());
First, the highlightOnLoad function checks window.location.search to see if we need to be running any of this stuff, then calls getSearchString to get a sanitized search string so that nothing funky can happen if, say, the user searches for <script>. You should really be sanitizing all search inputs at least on the back-end anyway.
Then, the highlightTextNodes function uses a regex replace on our textContainerNode’s innerHTML. The regex verifies that the text is between a > and a < (and not the other way around). Actually nice and simple!
Caveats
This may end up being a bit slow if you are doing this on a LOT of text, but for my blog text, it seems quite snappy to me. Also, the CSS does not bold text inside links, but the background color is there to make it obvious.
What do you think? Try it out on the search box on the upper-right. I’m hoping for some optimizations in the comments.