当我们在使用大多数的网页搜索引擎的"网页快照"功能时,他们都会在返回的快照页面中加入要害字高亮的功能。这将非常方便我们查找网页中被检索的内容,其中google快照的要害字高亮还融入了分词功能,不同的词着以不同的颜色。可是由于%!#^*%26amp;$!的原因,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%26amp;newwindow=1%26amp;q=apache+asp.net%26amp;btnG=%E6%90%9C%E7%B4%A2%26amp;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 %26amp;%26amp; 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 %26lt; keywords.length ; ++i )
{
var keyword = keywords[i];
if ( keyword %26amp;%26amp; keyword.length %26gt; 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);
}
}
}
}
