利用搜尋引擎引用來高亮頁面關鍵字

來源:互聯網
上載者:User
關鍵字|搜尋引擎|頁面

    當我們在使用大多數的網頁搜尋引擎的"網頁快照"功能時,他們都會在返回的快照頁面中加入關鍵字高亮的功能。這將非常方便我們尋找網頁中被檢索的內容,其中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);
             }
         }
     }
}



相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。