我正在为菜单项使用master。由于我使用母版页,我很困惑如何突出显示活动菜单项。谁能帮我吗。由于我有4页,我在4页的所有页面加载事件中尝试了以下代码,但没有用。
if (!IsPostBack)
{
Menu M = (Menu)this.Master.FindControl("menu");
foreach (MenuItem item in M.Items)
{
if (item.Text == "update")
{
item.Selected = true;
}
}
}
<div id="menu">
<ul>
<li>
<asp:LinkButton ID="update" runat="server" OnClick="update_Click">Update</asp:LinkButton></li>
<li>
<asp:LinkButton ID="bulk" runat="server" OnClick="bulkupdate_Click">Bulk</asp:LinkButton></li>
<li>
<asp:LinkButton ID="profiles" runat="server" OnClick="userprofiles_Click">Profiles</asp:LinkButton></li>
<li>
<asp:LinkButton ID="help" runat="server" OnClick="help_Click">Help</asp:LinkButton></li>
</ul>
</div>
#menu ul {
margin: 0;
padding: 7px 6px 0;
background: #b6b6b6 url('/Images/Overlay.png') repeat-x 0 -110px;
line-height: 100%;
border-radius: 1em;
font: normal 0.5333333333333333em Arial, Helvetica, sans-serif;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
-webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
-moz-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
width 100%;
}
#menu li {
margin: 0 5px;
padding: 0 0 8px;
float: left;
position: relative;
list-style: none;
}
#menu a,
#menu a:link {
font-weight: bold;
font-size: 16px;
color: #444444;
text-decoration: none;
display: block;
padding: 8px 20px;
margin: 0;
border-radius: 5px;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
}
#menu a:hover {
background: #000;
color: #fff;
}
#menu .active a,
#menu li:hover > a {
background: #bdbdbd url('/Images/Overlay.png') repeat-x 0 -40px;
background: #666666 url('/Images/Overlay.png') repeat-x 0 -40px;
color: #444;
border-top: solid 1px #f8f8f8;
-webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
-moz-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
text-shadow: 0 1px 0 #ffffff;
}
#menu ul ul li:hover a,
#menu li:hover li a {
background: none;
border: none;
color: #666;
-webkit-box-shadow: none;
-moz-box-shadow: none;
}
#menu ul ul a:hover {
background: #7d7d7d url('/Images/Overlay.png') repeat-x 0 -100px !important;
color: #fff !important;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
}
#menu li:hover > ul {
display: block;
}
#menu ul ul {
display: none;
margin: 0;
padding: 0;
width: 185px;
position: absolute;
top: 40px;
left: 0;
background: url('/Images/Overlay.png') repeat-x 0 0;
border: solid 1px #b4b4b4;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
-webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
-moz-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}
#menu ul ul li {
float: none;
margin: 0;
padding: 3px;
}
#menu ul ul a,
#menu ul ul a:link {
font-weight: normal;
font-size: 12px;
}
#menu ul:after {
content: '.';
display: block;
clear: both;
visibility: hidden;
line-height: 0;
height: 0;
}
* html #menu ul {
height: 1%;
}
答案 0 :(得分:0)
根据您所在的页面,您无法在document.ready中使用Jquery设置活动项目?虽然不是很好的做法..如果菜单项增加,这可能需要更改代码。
答案 1 :(得分:0)
将CSS用于活动菜单 像
active{
background-color: #CDE3F7;
border-radius: 5px;
color: #000000;
text-decoration: none;
}
答案 2 :(得分:0)
使用下面的asp.net菜单控件......
<asp:Menu Width="100%" ItemWrap="true" ID="SelectMenu" runat="server" DynamicHorizontalOffset="2"
StaticSubMenuIndent="10px" CssClass="menubar" Orientation="Horizontal">
<DynamicHoverStyle CssClass="menuitem-hover" />
<DynamicMenuItemStyle HorizontalPadding="2px" CssClass="menuitem" />
<DynamicMenuStyle BackColor="#F7F6F3" CssClass="IE8Fix" />
<DynamicSelectedStyle CssClass="menuitemsel" />
<StaticHoverStyle ForeColor="Yellow" />
<StaticMenuItemStyle HorizontalPadding="15px" VerticalPadding="0px" CssClass="menu" />
<StaticSelectedStyle CssClass="menuitemselstatic" />
<Items>
</items>
</asp:Menu>
答案 3 :(得分:0)
@ user3003821 - 检查一下 很脏,但有效
MasterPage HTML:
<div id="MenuHolderDiv">
<ul>
<li class="menuLst"><a href="#" id="MenuItem1" onclick="redirectOnClick(this)">MenuItem1</a></li>
<li class="menuLst"><a href="#" id="MenuItem2" onclick="redirectOnClick(this)">MenuItem2</a></li>
<li class="menuLst"><a href="#" id="MenuItem3" onclick="redirectOnClick(this)">MenuItem3</a></li>
<li class="menuLst"><a href="#" id="MenuItem4" onclick="redirectOnClick(this)">MenuItem4</a></li>
</ul>
</div>
</div>
母版页:脚本:
<script type="text/javascript">
$(document).ready(function () {
var pageName = getPageName(window.location.href);
$("#" + pageName).addClass("active");
$("#" + pageName).parent().addClass("activeLst");
});
function getPageName(url) {
var index = url.lastIndexOf("/") + 1;
var filenameWithExtension = url.substr(index);
var filename = filenameWithExtension.split(".")[0];
return filename;
}
function redirectOnClick(item) {
debugger;
window.location.href = $(item).text() + ".aspx";
}
</script>
样式表:
.menuLst
{
float:left;
display:inline;
background-color:Gray;
padding:2x;
}
.menuLst a
{
color:Black;
text-decoration:none;
}
.menuLst a:hover
{
color:white;
text-decoration:none;
}
.menuLst a:active
{
color:Green;
text-decoration:none;
}
.menuLst:hover
{
background-color:Black;
text-decoration:none;
}
.active
{
color:Green !important;
text-decoration:none;
}
.activeLst
{
background-color:Black;
}
条件:用于菜单项的PageName和ID必须相同
答案 4 :(得分:0)
使用Bootstrap和jQuery
$(function () {
$(".navbar‐btn a").each(function () {
if (this.href.trim().split("/").splice(3, 4)[0] == window.location.pathname.split("/").splice(1, 1)[0])
$(this).parent().addClass("active");
});
})