当我们在使用大多数的网页搜索引擎的"网页快照"功能时,他们都会在返回的快照页面中加入关键字高亮的功能。这将非常方便我们查找网页中被检索的内容,其中google快照的关键字高亮还融入了分词功能,不同的词着以不同的颜色。可是由于%!#^*&$!的原因,google的网页快照非常的不稳定,那么我们就自己来加上这个关键字高亮功能吧。 如下图,当我们在google中搜索了关键字:apache asp.net后的结果: 点击结果的连接并导航到我们自己的页面后,如果我们加以如下关键字高亮,是否会对用户快速查找和定位页面感兴趣的内容,提供方便呢? 按么我们来仔细的看看,可是IE中的地址明明是:http://birdshome.cnblogs.com/archive/2005/11/17/Apache.html,那么怎么能在页面中高亮由搜索引擎检索的关键字呢?这里我们是利用了document的referrer属性来获取搜索引擎类型和关键字信息的。比如上例中,document.referrer属性就为:http://www.google.com/search?hl=zh-CN&newwindow=1&q=apache+asp.net&btnG=%E6%90%9C%E7%B4%A2&lr=lang_zh-CN%7Clang_zh-TW。我们通过JavaScript分析出指定搜索引擎的关键字,再操作页面DOM对象就实现了高亮的功能。不过对于较长的连续中文关键字,这种客户端高亮方案是不可能提供分词功能的,也算是美中不足了。 具体实现当前页面被检索关键字高亮的代码如下,放入页面的document.body.onload事件中调用就行了:) function FriendlyDisplayForSearch() { var url = new UrlBuilder(document.referrer); if ( url.m_Success ) { var host = url.m_Host.toLowerCase(); if ( host.indexOf('.google.') != -1 ) { var keywords = url.GetValue('q', 'UTF8'); if ( keywords ) { var ht = new HighlightText(); ht.Execute(keywords); } } else if ( host.indexOf('.baidu.') != -1 ) { } } }// 由于编码和使用频率的关系,目前只做了google搜索引擎 function HighlightText(range) { if ( range ) { this.m_Range = range; } else { this.m_Range = document.body.createTextRange(); } this.m_Keyword = ''; this.toString = function() { return '[class HightlightText]'; }; } HighlightText.prototype.Execute = function(keyword) { if ( keyword ) { this.m_Keyword = keyword; } if ( this.m_Range && this.m_Keyword ) { var separater = ' '; if ( this.m_Keyword.indexOf(' ') == -1 ) { separater = '+'; } var keywords = this.m_Keyword.split(separater); var bookmark = this.m_Range.getBookmark(); for ( var i=0 ; i < keywords.length ; ++i ) { var keyword = keywords[i]; if ( keyword && keyword.length > 1 ) { while(this.m_Range.findText(keywords[i])) { this.m_Range.execCommand('ForeColor', 'false', 'highlighttext'); this.m_Range.execCommand('BackColor', 'false', 'highlight'); this.m_Range.collapse(false); } this.m_Range.moveToBookmark(bookmark); } } } } |
|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )
GMT+8, 2024-9-30 15:36 , Processed in 0.108933 second(s), 12 queries , Gzip On, MemCache On.
Powered by Discuz! X3.5
© 2001-2023 Discuz! Team.