导航栏 - 如何在选中时突出显示页面?

时间:2014-04-23 07:59:35

标签: html css

我有一个导航栏,当你悬停时它会改变颜色(向用户显示将被选中的内容)。但是,如果用户点击它,我希望该栏保持“突出显示”的颜色,这样他们就可以看到他们所在的页面(然后如果他们点击新页面,它将突出显示该页面 - 基本上我该如何保持最后一页突出显示? 如果你在这个网站上看,这就是我希望它工作的方式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;
}
}

以下是演示:http://jsfiddle.net/B9CPg/3/

5 个答案:

答案 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中实现的唯一方式,但是并非没有陷阱。

Demo Fiddle

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>

http://jsfiddle.net/B9CPg/19/

答案 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