我有ListView
我在网站上用作导航菜单。我想添加一些Jquery效果,使它看起来不错。我添加了这个脚本并且Jquery可以工作,但是当我点击链接时,或者例如,如果我点击
<a class="head" href="<%#: GetRouteUrl("ProductsByCategoryRoute", new {categoryName = Item.CategoryName}) %>">
<%#: Item.CategoryName %>
</a>
我的子菜单会下降并变得可见,但它不会执行href
。与显示的子链接相同。当我点击它确实空回发。因为此菜单会执行查询并根据您单击的内容显示结果。我应该在服务器端做这些手风琴效果吗?
为什么让这个Jquery阻止我的路由链接工作。
jquery脚本:
<script>
var $open = $();
$('.head').click(function (e) {
e.preventDefault();
$open.slideUp();
$open = $(this).closest('li').find('.content');
$open.not(':animated').slideToggle();
});
</script>
标记:
<asp:ListView ID="categoryList" runat="server"
OnItemDataBound="brandList_ItemDataBound" ItemType="E_Store_Template.Models.Category" SelectMethod="GetCategories">
<LayoutTemplate>
<ul style="list-style-type: none;">
<asp:PlaceHolder runat="server" ID="itemPlaceholder" />
</ul>
</LayoutTemplate>
<ItemTemplate>
<li style="text-align: left;">
<b style="font-size: large; font-style: normal">
<a class="head" href="<%#: GetRouteUrl("ProductsByCategoryRoute", new {categoryName = Item.CategoryName}) %>">
<%#: Item.CategoryName %>
</a>
</b>
<asp:ListView ID="brandList" runat="server" ItemType="E_Store_Template.Models.Brand">
<LayoutTemplate>
<ul style="list-style-type: none; text-align: left;">
<asp:PlaceHolder runat="server" ID="itemPlaceholder" />
</ul>
</LayoutTemplate>
<ItemTemplate>
<li>
<a class="content" href="<%#: GetRouteUrl("ProductsByCatBrandRoute", new { brandName = Item.BrandName })%>">
<%#: Item.BrandName %>
</a>
</li>
</ItemTemplate>
</asp:ListView>
</li>
</ItemTemplate>
</asp:ListView>
来源
所有产品
<ul style="list-style-type: none;">
<li style="text-align: left;">
<b style="font-size: large; font-style: normal">
<a class="head" href="/ProductList/Rods">
Rods
</a>
</b>
<ul style="list-style-type: none; text-align: left;">
<li>
<a class="content" href="">
Brand1
</a>
</li>
<li>
<a class="content" href="">
Brand2
</a>
</li>
</ul>
</li>
<li style="text-align: left;">
<b style="font-size: large; font-style: normal">
<a class="head" href="/ProductList/Reels">
Reels
</a>
</b>
<ul style="list-style-type: none; text-align: left;">
<li>
<a class="content" href="">
Brand1
</a>
</li>
<li>
<a class="content" href="">
Brand2
</a>
</li>
<li>
<a class="content" href="">
Brand3
</a>
</li>
</ul>
</li>
<li style="text-align: left;">
<b style="font-size: large; font-style: normal">
<a class="head" href="/ProductList/Tackle">
Tackle
</a>
</b>
<ul style="list-style-type: none; text-align: left;">
<li>
<a class="content" href="">
Brand1
</a>
</li>
<li>
<a class="content" href="">
Brand2
</a>
</li>
<li>
<a class="content" href="">
Brand3
</a>
</li>
</ul>
</li>
<li style="text-align: left;">
<b style="font-size: large; font-style: normal">
<a class="head" href="/ProductList/Apparel">
Apparel
</a>
</b>
<ul style="list-style-type: none; text-align: left;">
<li>
<a class="content" href="">
Brand1
</a>
</li>
</ul>
</li>
</ul>
</section>
答案 0 :(得分:0)
<script>
var $open = $();
$('.head').click(function (e) {
// e.preventDefault();
$open.slideUp();
$open = $(this).closest('li').find('.content');
$open.not(':animated').slideToggle();
});
</script>
这修好了!