页面刷新后如何链接获取焦点

时间:2013-07-23 02:08:38

标签: javascript jquery asp.net-mvc-3 css3

我的问题是:当我点击一个按钮然后刷新页面时,我希望我的菜单清除以前访问过的链接(再次将它们恢复正常),但将当前访问的链接保持为:在css中访问。

我认为这很简单,但我从网络编程开始,所以我需要帮助。我找到了一种方法来做到这一点。但问题是它不起作用!!这是我的代码:

< ul id="menuTop">
  < li id="menu-link-1">
@Html.ActionLink("Home", "Index", null, null, new { id = "link-1-visited" }) < /li>
< li id="menu-link-2">
@Html.ActionLink("Produtos", "Products", null, null, new { id = "link-2-visited" })  < /li>
< li id="menu-link-3">
@Html.ActionLink("Fale Conosco", "ContactUs", null, null, new { id = "link-3-visited" })  < /li>
< li id="menu-link-4">
@Html.ActionLink("Quem Somos", "AboutUs", null, null, new { id = "link-4-visited" })  < /li>
< /ul>

这是我的按钮,让他们“访问”的代码是:

$(document).ready(function() {
$('#link-1-visited').click(function() {
    $("#menu-link-1").removeAttr("menu-link-1");
    $(this).addClass('link-1-visited');
    window.alert("test 1 !!");
});

$('#link-2-visited').click(function() {
    $(this).addClass('link-1-visited');
    window.alert("test 2 !!");
});

$('#link-3-visited').click(function() {
    $(this).addClass('link-1-visited');
    window.alert("test 3 !!");
});

$('#link-4-visited').click(function() {
    $(this).addClass('link-1-visited');
    window.alert("test 4 !!");
});
});

我在css中的代码是:

ul#menuTop li#menu-link-1 a {
    background-image: url("../Content/images/Menu/menu-image-1-alt.png");
    margin-right: 1px;
}

ul#menuTop li#menu-link-1 a:hover {
    background-image: url("../Content/images/Menu/menu-image-1-hover.png");
    margin-right: 1px;
}

.link-1-visited {
    padding: 40px 20px 20px;
    border-width: 3px;
    border-bottom: 0px;
    // more styles below...
}

ul#menuTop li a {
    border: 3px #98fb98 solid;
    border-bottom: 0px;
    //more styles below...
}

ul#menuTop li a:hover {
    padding: 40px 20px 20px;
    border-width: 3px;
    border-bottom: 0px;
    border-style: solid;
    //more styles below...
}

问题是我在menu-link-1中的代码无效。我想删除ul和li css并向其添加“link-1-visited”类。

您对我该怎么做有什么想法吗?

2 个答案:

答案 0 :(得分:2)

基本上你需要设置链接以保持css中的一种颜色,所以......

a, a:visited { 
    color: blue;
}

然后你只需在点击事件中使用jQuery更改颜色:

$("a").click(function() {
    ($this).css({"color":"white"});
});

只需更改值以适合您正在使用的值,您应该全部设置。

对于您尝试执行的操作,请在此处查看会话变量:Java session variables

答案 1 :(得分:0)

/* change the id name according to the page link you want to make focused */
var page = document.getElementById("index").href;
if (page == index) {
  document.getElementById("index").className = "active";
}
ul {
  list-style-type: none;
}

li a {
  display: block;
  cursor: pointer;
  text-decoration: none;
  padding: 10px 20px;
  font-size: 13.8px;
  font-family: Verdana, Geneva, Tahoma, sans-serif;
  text-transform: uppercase;
  color: #555555;
  font-style: normal;
  white-space: nowrap;
  border-radius: 10px;
  transition: background-color .4s;
}

.active {
  background-color: rgba(0, 0, 0, 0.9);
  border-radius: 10px;
  color: rgb(255, 204, 65);
}
<ul>
  <li><a id="index" href="index.html">Overview</a></li>
  <li><a id="wed" href="wed.html">Wedding</a></li>
  <li><a id="engage" href="engage.html">Engagement</a></li>
</ul>