[英]How to write this simple javascript or jquery?
我有一些像这样的导航链接:
<ul id="nav">
<li><a href="index.html">Home</a>
<li><a href="about.html">About</a>
<li><a href="contact.html">Contact</a>
</ul>
如何将名为active
的CSS类添加到包含其值与当前url匹配的a href
的列表项的开始<li>
标记中?
例如,如果用户所在的当前页面是about.html
那么导航应如下所示:
<ul id="nav">
<li><a href="index.html">Home</a>
<li class="active"><a href="about.html">About</a>
<li><a href="contact.html">Contact</a>
</ul>
请注意:
网址可以有其他参数,如:
about.html?富=酒吧和酒吧= 1.00
因此,用于检测网址的任何内容都不应考虑参数,而只考虑页面名称和扩展名。
我更喜欢在普通的JavaScipt中实现这一点,因为我没有在网站上使用jQuery,但是其中一个很好。
当它从另一个页面登陆时,索引页面在url中有index.html,但如果域是类型,则显示为:
http://www.sitename.com/
因此,如果未指定页面,则应将活动类附加到主列表的标记。
jQuery的:
if(window.location.pathname === '') {
$('#nav li:first-child').addClass('active');
}
else {
var path = window.location.pathname;
path = path.substr(path.lastIndexOf('/') + 1);
$('#nav li').filter(function(index) {
return path === $(this).children('a').attr('href');
}).addClass('active');
}
普通的JavaScript:
var menu_elements = document.getElementById('nav').children;
if(window.location.pathname === '') {
menu_elements[0].className += ' active';
}
else {
var path = window.location.pathname;
path = path.substr(path.lastIndexOf('/') + 1);
for(var i = menu_elements.length; i--;) {
var element = menu_elements[i];
var a = element.children[0];
if(a.href === path) {
element.className += ' active';
break;
}
}
}
注意: FF 3.0不支持children[]
。 如果您遇到任何与children
问题,可以使用适当的getElementsByTagName
调用替换它。
简单版
window.onload=function() {
var activeLi;
if (location.pathname) {
var fileName = location.pathname.substring(pathname.lastIndexof('/')+1);
/* just take the start -
not handling filenames that are substrings of other filenames
nor filenames with more than one dot. */
fileName = fileName.split('.')[0];
var links = document.getElementById('nav').getElementsByTagName('a');
for (var i=0;i<links.length;i++) {
if (links[i].href.indexOf(fileName)==0) { // starts with filename
activeLi = links[i].parentNode;
break;
}
}
}
else { // no page given
activeLi = document.getElementById('nav').getElementsByTagName('li')[0];
}
if (activeLi) activeLi.className="active";
}
更复杂的是将活动添加到className,但是如果你没有在LI上有其他类,那么它就不需要 - 但是如果你使用jQuery则更简单。
//Get sub-domain url
var currentUrl = window.location.href,
splitUrlArr = currentUrl.replace(/\?.*/,'').split('\/');
subDomainUrl = splitUrlArr[splitUrlArr.length-1];
//if url matches the site home url, add classname 'active' to first li
if(splitUrlArr.join('\/') == currentUrl) {
document.getElementById('nav').getElementsByTagName('li')[0].className = "active";
}else {
//Find the matching href and add className 'active' to its parent li
var targetLi = null;
var links = document.getElementById('nav').getElementsByTagName('a');
for (var i=0; i < links.length; i++) {
if (links[i].href === subDomainUrl) {
targetLi = links[i].parentNode;
break;
}
}
if(targetLi) { targetLi.className = "active"; }
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.