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


    http://www.cnblogs.com/birdshome/archive/2006/02/23/HighlightText.html


    利用搜索引擎引用来高亮页面关键字
        当我们在使用大多数的网页搜索引擎的"网页快照"功能时,他们都会在返回的快照页面中加入关键字高亮的功能。这将非常方便我们查找网页中被检索的内容,其中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)
    {
        
    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);
                 }

             }

         }

    }

        其它参考:UrlBuilder
        相关文章:
            ·注入Script增加了一个GoogleTrack功能
            ·用脚本为本blog增加了几项自定义功能
  • 相关阅读:
    python中列表排序的方法
    pyrhon3中字符串方法
    python数据探索与数据与清洗概述
    2020年日期表-python实现
    python中字符串离散化的例子
    python中常见的日期处理方法
    如何简单地理解Python中的if __name__ == '__main__'
    我的老爸老了
    关于
    关于
  • 原文地址:https://www.cnblogs.com/flyfish/p/773048.html
Copyright © 2020-2023  润新知