我有一个简单的 jquery下拉菜单。但问题是如果列表有子菜单,如何像其他常用菜单一样将箭头或只是'+'字符相互放置。
function Mx_menu(){
$(".menu ul").css({display: "none"}); // Opera Fix
$(".menu li").hover(function(){
$(this).find('ul:first').css({visibility: "visible",display: "none"}).show(400);
},function(){
$(this).find('ul:first').css({visibility: "hidden"});
});
}
$(document).ready(function(){
Mx_menu();
});
这里的CSS文件:
.menu, .menu ul { margin:0; padding:0; list-style-type:none; list-style-position:outside; position:relative; }
.menu a { color:#a6a6a6; display:block; padding:6px 10px; }
.menu li { float:left; position:relative; width:200px; }
.menu ul { position:absolute; display:none; width:200px; top:0; left:200px; }
.menu li ul a { width:200px; height:auto; float:left; }
.menu ul ul { top:auto; }
.menu li ul ul { left:200px; margin:0; }
.menu li:hover ul ul, .menu li:hover ul ul ul, .menu li:hover ul ul ul ul { display:none; }
.menu li:hover ul, .menu li li:hover ul, .menu li li li:hover ul, .menu li li li li:hover ul { display:block; }
答案 0 :(得分:2)
最终我找到了一个解决方案,所以它被称为:prev():
$(".menu li ul").prev().css("background", "url(IMG_URL) transparent");
这里的最终jquery代码:
function Mx_menu(){
$(".menu li ul").prev().css("background", "url('IMG_URL')");
$(".menu ul").css({display: "none"}); // Opera Fix
$(".menu li").hover(function(){
$(this).find('ul:first').css({visibility: "visible",display: "none"}).show(400);
},function(){
$(this).find('ul:first').css({visibility: "hidden"});
});
}
$(document).ready(function(){
Mx_menu();
});
答案 1 :(得分:0)
你可以做这样简单的事情,在使用.before()
+
内的<ul>
之前的<li>
前面添加$(".menu li ul").before(' +');
(或任何ASCII字符),就像这样:
{{1}}
答案 2 :(得分:0)
.menu li:hover ul li { background:transparent url( IMG_PATH ) left center no-repeat; padding-left:12px; }
注意在IE6中缺少对li的伪选择器的支持。