Html 导航栏-选择后如何保持页面高亮显示?

Html 导航栏-选择后如何保持页面高亮显示?,html,css,Html,Css,我有一个导航栏,当你悬停时,它会改变颜色,向用户显示将要选择的内容。但是,如果用户点击,我希望该栏保持“突出显示”的颜色,这样他们就可以看到他们在哪个页面上,如果他们点击一个新页面,它就会突出显示该页面-基本上我如何保持最后一个页面突出显示? 如果你看这个网站,这就是我希望它的工作方式 理想情况下,我希望通过CSS实现这一点 以下是HTML: <div id='cssmenu'> <ul> <li><a href='#'><span&

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

理想情况下,我希望通过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>

演示如下:

只需创建一个活动类,并在单击链接时使用Jquery添加和删除它

Jquery

CSS

这是一个


使用颜色而不是背景。此外,仅针对您的cssmenu div&links,您可以在每页的每个菜单中放置:visted或类。例如,您当前所在的主页:


然后在访问的类中放置一个css

如果我们谈论的是在不加载页面的情况下保持高亮显示,那么您可以使用以下纯CSS/HTML

然而,正如King在评论中所指出的,这可能是仅在CSS中实现的唯一方法,但并非没有陷阱

HTML


将此部分添加到CSS中

.active {
    color: #83c9ff; 
}
然后将活动CLA放入相关菜单项

例如:-在你的托管页面中添加

<li class='active'><a href='#'><span>Hosting</span></a>

我的建议是使用简单的jQuery。 我已经看到您添加了.active样式 加上

$("#cssmenu > ul > li").click(function(){
    $("#cssmenu > ul > li").removeClass("active");
    $(this).addClass('active');
});
对于document.ready事件,此函数的作用是,每次单击cssmenu中的li,它都会清除所有li。active类,然后将.active添加到请求的.li中

下面是一个演示:


否则,如果它不是相同的链接菜单,只需为每个页面添加.active即可

我不认为基于:focus to style selected选项卡是一个好主意,当任何其他元素获得焦点时,所选的标签将不再是样式,因为它应该是任何你是对的-我应该注意到,这是唯一的方法,这样做只使用CSS作为OP要求-好注意,将结束
<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>
@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;
    }
}
.active {
    color: #83c9ff; 
}
<li class='active'><a href='#'><span>Hosting</span></a>
$("#cssmenu > ul > li").click(function(){
    $("#cssmenu > ul > li").removeClass("active");
    $(this).addClass('active');
});