我做了一个 jquery 折叠和展开 div。它工作,但我面临一个问题,只有 [+] 和跨度 [-] 是可点击的,但我希望 li 意味着<li>main link 1<span>[+]</span>
可点击
<ul class="link">
<li>main link 1<span>[+]</span>
<ul class="inner_div">
<li><a>test 1</a>
</li>
<li><a>test 2</a>
</li>
<li><a>test 3</a>
</li>
</ul>
</li>
</ul>
<ul class="link">
<li>main link 2<span>[+]</span>
<ul class="inner_div">
<li><a>test 1</a>
</li>
<li><a>test 2</a>
</li>
<li><a>test 3</a>
</li>
</ul>
</li>
</ul>
<ul class="link">
<li>main link 3<span>[+]</span>
<ul class="inner_div">
<li><a>test 1</a>
</li>
<li><a>test 2</a>
</li>
<li><a>test 3</a>
</li>
</ul>
</li>
</ul>
<ul class="link">
<li>main link 4<span>[+]</span>
<ul class="inner_div">
<li><a>test 1</a>
</li>
<li><a>test 2</a>
</li>
<li><a>test 3</a>
</li>
</ul>
</li>
脚本是:-
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"> </script>
<script>
$('.link span').click(function () {
var $ul = $(this).next();
$(".inner_div").not( $ul ).hide();
$( '.link span' ).html( '[+]' );
if( !$ul.is( ':visible' ) ) {
$( this ).html( '[–]');
}
$ul.slideToggle();
});
$(document).ready(function(){
$( '.link' ).first().click();
});
</script>
CSS是: -
.inner_div{ display:none; }
.link span { float: right; cursor: pointer; }
请帮我。