利用搜索引擎引用来高亮页面关键字

本文介绍了一种在网页中实现搜索引擎关键词高亮显示的方法。通过分析referrer中的搜索引擎信息及关键词,利用JavaScript操作DOM实现文本高亮。适用于Google等搜索引擎。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当我们在使用大多数的网页搜索引擎的"网页快照"功能时,他们都会在返回的快照页面中加入关键字高亮的功能。这将非常方便我们查找网页中被检索的内容,其中google快照的关键字高亮还融入了分词功能,不同的词着以不同的颜色。可是由于%!#^*&$!的原因,google的网页快照非常的不稳定,那么我们就自己来加上这个关键字高亮功能吧。

    如下图,当我们在google中搜索了关键字:apache asp.net后的结果:
    GoogleResult.png

    点击结果的连接并导航到我们自己的页面后,如果我们加以如下关键字高亮,是否会对用户快速查找和定位页面感兴趣的内容,提供方便呢?
    HighlightText.gif
    
    按么我们来仔细的看看,可是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)


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);
             }

         }

     }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值