jquery:切换子项 onclick

发布于 2024-10-01 08:41:47 字数 717 浏览 0 评论 0 原文

单击“+”时,什么 js/jquery 代码会使下面的列表切换子项?

<ul>  
<li id="1" parent="0"><a href="#">1</a></li>  
    <li id="2" parent="0"><a href="#"> + </a><a href="#">2</a>  
        <ul parent="2">  
            <li id="23" parent="2"><a href="#">2.1</a></li>  
            <li id="50" parent="2"><a href="#"> + </a><a href="#">2.2</a>  
                <ul parent="50">  
                    <li id="123" parent="50"><a  href="#">2.50.1</a></li>  
                </ul>  
            </li>  
        </ul>  
    </li>
</ul>

what js/jquery code would make below list toggle children when clicking "+" ?

<ul>  
<li id="1" parent="0"><a href="#">1</a></li>  
    <li id="2" parent="0"><a href="#"> + </a><a href="#">2</a>  
        <ul parent="2">  
            <li id="23" parent="2"><a href="#">2.1</a></li>  
            <li id="50" parent="2"><a href="#"> + </a><a href="#">2.2</a>  
                <ul parent="50">  
                    <li id="123" parent="50"><a  href="#">2.50.1</a></li>  
                </ul>  
            </li>  
        </ul>  
    </li>
</ul>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

风和你 2024-10-08 08:41:47

您可以使用 .toggle().slideToggle().siblings(),如下所示:

$("ul a:contains( + )").click(function() {
  $(this).siblings("ul").toggle();
});

您可以在这里测试一下。请注意,尽管您的 ID 和属性无效,但您可能需要使用 data-< /code> 属性 在这里。另外,我建议为这些 + 链接提供一个类,以使选择器更加更加高效,例如:

<a href="#" class=".toggle"> + </a>

然后像这样绑定:

$("ul a.toggle").click(function() {
  $(this).siblings("ul").toggle();
});

You can use .toggle() or .slideToggle() with .siblings(), like this:

$("ul a:contains( + )").click(function() {
  $(this).siblings("ul").toggle();
});

You can test it out here. Note though your IDs and attributes are invalid, you may want to use data- attributes here. Also, I suggest giving those + links a class, to make the selector much more efficient, for example:

<a href="#" class=".toggle"> + </a>

Then binding like this:

$("ul a.toggle").click(function() {
  $(this).siblings("ul").toggle();
});
苏璃陌 2024-10-08 08:41:47

像这样的东西

$("ul a:contains('+')").click(function () {
  var $this = $(this);
  $this.siblings("ul").show();
});

Something like this

$("ul a:contains('+')").click(function () {
  var $this = $(this);
  $this.siblings("ul").show();
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文