|
JS判斷當(dāng)前URL對(duì)當(dāng)前欄目高亮顯示,重點(diǎn)是用到了indexOf來判斷兩個(gè)字符串中第一次出現(xiàn)的位置,如果沒有出現(xiàn)就返回-1,出現(xiàn)就返回
其它,并與返回其它結(jié)果的那個(gè)字符串所在元素定義一個(gè)class.
HTML
復(fù)制代碼 代碼如下:
<div id="nav">
<ul>
<li><a href="http://www.jb51.NET/html/list/index_127.htm" title="資訊中心"><span>資訊中心</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_1.htm" title="網(wǎng)絡(luò)編程"><span>網(wǎng)絡(luò)編程</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_104.htm" title="數(shù)據(jù)庫(kù)"><span>數(shù)據(jù)庫(kù)</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_96.htm" title="腳本專欄"><span>腳本專欄</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_7.htm" title="實(shí)用技巧"><span>實(shí)用技巧</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_84.htm" title="軟件編程"><span>軟件編程</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_8.htm" title="網(wǎng)頁(yè)制作"><span>網(wǎng)頁(yè)制作</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_86.htm" title="操作系統(tǒng)"><span>操作系統(tǒng)</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_11.htm" title="經(jīng)典網(wǎng)摘"><span>經(jīng)典網(wǎng)摘</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_27.htm" title="網(wǎng)站技巧"><span>網(wǎng)站技巧</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_99.htm" title="免費(fèi)資源"><span>免費(fèi)資源</span></a></li>
<li><a href="http://www.jb51.NET/html/list/index_54.htm" title="關(guān)于我們"><span>關(guān)于我們</span></a></li>
<li><a href="http://www.jb51.NET/search.ASP" title="文章搜索"><span>文章搜索</span></a></li>
</ul>
</div>
JS
復(fù)制代碼 代碼如下:
var myNav = document.getElementById("nav").getElementsByTagName("a");
for(var i=0;i<myNav.length;i++)
{
var links = myNav[i].getAttribute("href");
//alert(links)
//alert(myNav[i]);
var myURL = document.location.href;
if(myURL.indexOf(links) != -1)
{
myNav[i].className="d";
}
}
當(dāng)前欄目高亮顯示不知道你明白了沒有?沒有的話,我說詳細(xì)點(diǎn)。首先,你點(diǎn)擊一個(gè)連接,比如: <li><a
href="http://www.jb51.NET/html/list/index_127.htm" title="資訊中心">資訊中心</a></li>
點(diǎn)擊之后瀏覽器發(fā)生了什么變化呢?是的,就是地址欄變成了:
http://www.jb51.NET/html/list/index_127.htm
使用 document.location.href;
取得的就是這個(gè)地址(http://www.jb51.NET/html/list/index_127.htm)。
然后我們?cè)俦闅v當(dāng)前網(wǎng)頁(yè)上的所有連接,取得每個(gè)連接href的值。遍歷的代碼:
復(fù)制代碼 代碼如下:
var myNav = document.getElementById("nav").getElementsByTagName("a");
for(var i=0;i<myNav.length;i++)
{
var links = myNav[i].getAttribute("href");
}
使用indexOf函數(shù)來比較是否頁(yè)面的所有連接中,有關(guān)鍵字在http://www.jb51.NET/html/list/index_127.htm中出現(xiàn)。若有的話,就表
明是當(dāng)前連接,那么就修改當(dāng)前連接的樣式。這就實(shí)現(xiàn)了當(dāng)前欄目高亮顯示,當(dāng)前欄目高亮顯示是一個(gè)很實(shí)用的技巧,在增加用戶體驗(yàn)方面尤
其有好處。但在實(shí)用過程中,可能需要注意一些細(xì)節(jié)問題,比如搜索吧的博客是用外鏈的方式來連接的,那么在處理的時(shí)候,點(diǎn)了這個(gè)外鏈的
時(shí)候是否高亮呢?這里也只是我覺得當(dāng)前欄目高亮顯示時(shí)可能出現(xiàn)的問題稍微說一下,說不定你已經(jīng)有解決方法了。
JavaScript技術(shù):用js查找法實(shí)現(xiàn)當(dāng)前欄目的高亮顯示的代碼,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。