我有一个导航栏,当你悬停时它会改变颜色(向用户显示将被选中的内容)。但是,如果用户点击它,我希望该栏保持“突出显示”的颜色,这样他们就可以看到他们所在的页面(然后如果他们点击新页面,它将突出显示该页面 - 基本上我该如何保持最后一页突出显示? 如果你在这个网站上看,这就是我希望它工作的方式http://www.microsoft.com/web/
理想情况下,我想通过CSS来做到这一点。
这是HTML:
<div id='cssmenu'>
<ul>
<li><a href='#'><span>Home</span></a>
</li>
<li><a href='#'><span>Hosting</span></a>
</li>
<li><a href='#'><span>Domain Names</span></a>
</li>
<li><a href='#'><span>Servers</span></a>
</li>
<li><a href='#'><span>About Us</span></a>
</li>
<li class='last'><a href='#'><span>Support</span></a>
</li>
</ul>
</div>
CSS
@import url(http://fonts.googleapis.com/css?family=Open+Sans:700);
#cssmenu {
background: #000000;
width: auto;
position: relative;
top: 0;
}
#cssmenu ul {
list-style: none;
margin: 0;
padding: 0;
line-height: 1;
display: block;
zoom: 1;
}
#cssmenu ul:after {
content:' ';
display: block;
font-size: 0;
height: 0;
clear: both;
visibility: hidden;
}
#cssmenu ul li {
float: left;
display: block;
padding: 0;
}
#cssmenu ul li a {
color: #ffffff;
text-decoration: none;
display: block;
padding: 15px 15px;
font-family:'Open Sans', sans-serif;
font-weight: 700;
text-transform: uppercase;
font-size: 14px;
position: relative;
-webkit-transition: color .25s;
-moz-transition: color .25s;
-ms-transition: color .25s;
-o-transition: color .25s;
transition: color .25s;
}
#cssmenu ul li a:hover {
color: #83c9ff;
}
#cssmenu ul li a:hover:before {
width: 100%;
}
#cssmenu ul li a:after {
content:'';
display: block;
position: absolute;
right: -3px;
top: 19px;
height: 6px;
width: 6px;
background: #ffffff;
opacity: .5;
}
#cssmenu ul li a:before {
content:'';
display: block;
position: absolute;
left: 0;
bottom: 0;
height: 3px;
width: 0;
background: #83c9ff;
-webkit-transition: width .25s;
-moz-transition: width .25s;
-ms-transition: width .25s;
-o-transition: width .25s;
transition: width .25s;
}
#cssmenu ul li.last > a:after, #cssmenu ul li:last-child > a:after {
display: none;
}
#cssmenu ul li.active a {
color: #83c9ff;
}
#cssmenu ul li.active a:before {
width: 100%;
}
@media screen and (max-width: 768px) {
#cssmenu ul li {
float: none;
}
#cssmenu ul li a {
width: 100%;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
#cssmenu ul li a:after {
display: none;
}
#cssmenu ul li a:before {
height: 1px;
background: #ffffff;
width: 100%;
opacity: .2;
}
#cssmenu ul li.last > a:before, #cssmenu ul li:last-child > a:before {
display: none;
}
}
答案 0 :(得分:0)
只需创建一个活动类并使用Jquery添加它,并在单击链接时将其删除。
<强> Jquery的强>
$("a").click(function(){
$("a").removeClass("active");
$(this).addClass("active");
});
<强> CSS 强>
.active{
background: Red; //You can add any CSS you like here
}
这是fiddle
FIDDLE使用颜色而不是背景。此外,仅定位您的cssmenu
div&amp;链接
答案 1 :(得分:0)
您可以放置:访问过,或者如果您可以在每个页面的每个菜单中放置一个类。比如这个例如你当前在HOME页面:
<li><a href='#' class="visited"><span>Home</span></a>
</li>
<li><a href='#'><span>about</span></a>
</li>
然后在被访问的课程中输入一个CSS。
答案 2 :(得分:0)
如果我们谈论的是在没有页面加载的情况下保持突出显示,那么您可以使用以下 - 纯CSS / HTML。
正如 King King 在评论中指出的那样,这可能是仅在CSS中实现的唯一方式,但是并非没有陷阱。
HTML
<div id='cssmenu'>
<ul>
<li><a href='#' tabindex="1"><span>Home</span></a>
</li>
<li><a href='#' tabindex="2"><span>Hosting</span></a>
</li>
<li><a href='#' tabindex="3"><span>Domain Names</span></a>
</li>
<li><a href='#' tabindex="4"><span>Servers</span></a>
</li>
<li><a href='#' tabindex="5"><span>About Us</span></a>
</li>
<li class='last'><a href='#' tabindex="6"><span>Support</span></a>
</li>
</ul>
</div>
CSS
@import url(http://fonts.googleapis.com/css?family=Open+Sans:700);
#cssmenu {
background: #000000;
width: auto;
position: relative;
top: 0;
}
#cssmenu ul {
list-style: none;
margin: 0;
padding: 0;
line-height: 1;
display: block;
zoom: 1;
}
#cssmenu ul:after {
content:' ';
display: block;
font-size: 0;
height: 0;
clear: both;
visibility: hidden;
}
#cssmenu ul li {
float: left;
display: block;
padding: 0;
}
#cssmenu ul li a {
color: #ffffff;
text-decoration: none;
display: block;
padding: 15px 15px;
font-family:'Open Sans', sans-serif;
font-weight: 700;
text-transform: uppercase;
font-size: 14px;
position: relative;
-webkit-transition: color .25s;
-moz-transition: color .25s;
-ms-transition: color .25s;
-o-transition: color .25s;
transition: color .25s;
}
#cssmenu ul li a:hover,#cssmenu ul li a:focus {
color: #83c9ff;
outline:0;
}
#cssmenu ul li a:hover:before,#cssmenu ul li a:focus:before {
width: 100%;
}
#cssmenu ul li a:after {
content:'';
display: block;
position: absolute;
right: -3px;
top: 19px;
height: 6px;
width: 6px;
background: #ffffff;
opacity: .5;
}
#cssmenu ul li a:before {
content:'';
display: block;
position: absolute;
left: 0;
bottom: 0;
height: 3px;
width: 0;
background: #83c9ff;
-webkit-transition: width .25s;
-moz-transition: width .25s;
-ms-transition: width .25s;
-o-transition: width .25s;
transition: width .25s;
}
#cssmenu ul li.last > a:after, #cssmenu ul li:last-child > a:after {
display: none;
}
#cssmenu ul li.active a {
color: #83c9ff;
}
#cssmenu ul li.active a:before {
width: 100%;
}
@media screen and (max-width: 768px) {
#cssmenu ul li {
float: none;
}
#cssmenu ul li a {
width: 100%;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
#cssmenu ul li a:after {
display: none;
}
#cssmenu ul li a:before {
height: 1px;
background: #ffffff;
width: 100%;
opacity: .2;
}
#cssmenu ul li.last > a:before, #cssmenu ul li:last-child > a:before {
display: none;
}
}
答案 3 :(得分:0)
将此部分添加到CSS
.active {
color: #83c9ff;
}
然后将活动课程放到相关的菜单项目中。
例如: - 在您的托管页面中添加
<li class='active'><a href='#'><span>Hosting</span></a>
答案 4 :(得分:0)
我的建议是使用简单的jQuery。 我已经看到你添加了.active风格 只需添加
$("#cssmenu > ul > li").click(function(){
$("#cssmenu > ul > li").removeClass("active");
$(this).addClass('active');
});
在你的document.ready事件中,这个函数的作用是,在#cssmenu里面每次点击它都会清除它们的所有li .active class,然后将.active添加到你所请求的.li
以下是演示:http://jsfiddle.net/B9CPg/23/
否则,如果它不相同的链接菜单只为每个页面添加.active