javascript 获取搜索引擎关键字并高亮显示

作者: Codebit     来源: Codebit.cn     时间: 2007-03-15 23:42:53
摘要: 获取搜索引擎关键字并高亮显示能很大程度的提高用户体验,方便用户迅速找到自己需要的相关信息。本文介绍的是用客户端的 javascript 代码来实现这一目的。
归类: Javascript,

关键词: 链接, url, javascript, 高亮, 关键字, 搜索,

获取搜索引擎关键字并高亮显示能很大程度的提高用户体验,方便用户迅速找到自己需要的相关信息。本文介绍的是用客户端的 javascript 代码来实现这一目的。


示例:


您可以在 google 里搜索 "codebit.cn Javascript 锚点 平滑跳转" ,然后点击跳往本站的链接即可看到效果。


Javascript:
  1.  
  2. <script type="text/javascript">
  3. <!--
  4. // 说明:获取搜索引擎关键字并高亮显示
  5. // 整理:http://www.CodeBit.cn
  6.  
  7. /* http://www.kryogenix.org/code/browser/searchhi/ */
  8. /* Modified 20021006 to fix query string parsing and add case insensitivity */
  9. function highlightWord(node,word) {
  10. // Iterate into this nodes childNodes
  11. if (node.hasChildNodes) {
  12. var hi_cn;
  13. for (hi_cn=0;hi_cn<node.childNodes.length;hi_cn++) {
  14. highlightWord(node.childNodes[hi_cn],word);
  15. }
  16. }
  17. // And do this node itself
  18. if (node.nodeType == 3) { // text node
  19. tempNodeVal = node.nodeValue.toLowerCase();
  20. tempWordVal = word.toLowerCase();
  21. if (tempNodeVal.indexOf(tempWordVal) != -1) {
  22. pn = node.parentNode;
  23. if (pn.className != "searchword") {
  24. // word has not already been highlighted!
  25. nv = node.nodeValue;
  26. ni = tempNodeVal.indexOf(tempWordVal);
  27. // Create a load of replacement nodes
  28. before = document.createTextNode(nv.substr(0,ni));
  29. docWordVal = nv.substr(ni,word.length);
  30. after = document.createTextNode(nv.substr(ni+word.length));
  31. hiwordtext = document.createTextNode(docWordVal);
  32. hiword = document.createElement("span");
  33. hiword.className = "searchword";
  34. hiword.appendChild(hiwordtext);
  35. pn.insertBefore(before,node);
  36. pn.insertBefore(hiword,node);
  37. pn.insertBefore(after,node);
  38. pn.removeChild(node);
  39. }
  40. }
  41. }
  42. }
  43.  
  44. function googleSearchHighlight() {
  45. if (!document.createElement) return;
  46. ref = document.referrer;
  47. if (ref.indexOf('?') == -1) return;
  48. qs = ref.substr(ref.indexOf('?')+1);
  49. qsa = qs.split('&');
  50. for (i=0;i<qsa.length;i++) {
  51. qsip = qsa[i].split('=');
  52. if (qsip.length == 1) continue;
  53. if (qsip[0] == 'q' || qsip[0] == 'p') { // q= for Google, p= for Yahoo
  54. words = unescape(decodeURIComponent(qsip[1].replace(/\+/g,' '))).split(/\s+/);
  55. for (w=0;w<words.length;w++) {
  56. highlightWord(document.getElementsByTagName("body")[0],words[w]);
  57. }
  58. }
  59. }
  60. }
  61.  
  62. window.onload = googleSearchHighlight;
  63.  
  64. //-->
  65. </script>
  66.  



同时,您需要为要高亮的关键词设置一个样式:
CSS:
  1.  
  2. <style type="text/css">
  3. .searchword {
  4. background-color: yellow;
  5. }
  6. </style>
  7.  



实现原理:


在页面加载完成时获取页面来源(document.referrer),并分析搜索引擎关键词,然后获取页面上所有元素,递归查询是否含有搜索关键字,如果有,就创建一个 span 元素,并应用关键词样式,替换原有节点。


推荐链接:(联系 QQ :326801485)