jQuery - 仅切换下一个元素

标签 jquery jquery-selectors

我想用 jQuery 仅切换下一个元素(而不是其他元素):我将用示例来解释自己。

这是 HTML:

<article id="post-60" class="post-60 page type-page status-publish hentry">
    <header class="entry-header">
        <h1 class="entry-title">Pagine Critiche</h1>
    </header><!-- .entry-header -->

    <div class="entry-content">
        <p><strong>TITLE 1.1</strong></p>
        <p><strong>TITLE 1.2</strong></p>
        <p><em>Writer writes:</em></p>
        <p>Article #1</p>
        <p>&nbsp;</p>

        <p><strong>TITLE 2.1</strong></p>
        <p><strong>TITLE 2.2</strong></p>
        <p><em>Writer writes:</em></p>
        <p>Article #2.1</p>
        <p>Article #2.2</p>
        <p>Article #2.3</p>
    </div>
</article>

我想单击 TITLE 1.1 并显示(切换)TITLE 1 和 TITLE 2 之间的所有内容(因此第一个“strong p”和第二个“strong p”之间的所有内容);简而言之:我只想切换引用该标题的文章。

我尝试编写这个脚本:

$(document).ready(function(){
    $("#post-60 p strong").click(function(){
        $("p:not(:has(strong))").toggle(500);
    });
});

但它同时切换所有“正常”段落;这是fiddle .
我相信我需要 next() 选择器,但我没有以正确的方式使用它,就像我尝试过的那样:

$(document).ready(function(){
    $("#post-60 p strong").click(function(){
        $("p:not(:has(strong))").next().toggle(500);
    });
});

但它也不起作用。

我想解决这个问题,而无需编辑 HTML 标记。

最佳答案

如果您无法更新标记,请应用此 JS。

$(document).ready(function(){
    $("#post-60 p strong").click(function(){
        $(this).parent().next('p').nextUntil( "p:has(strong)").toggle(500);
    });
});

工作 fiddle https://jsfiddle.net/xpxhkh1r/3/

如果您可以重写标记,事情会简单得多。这是一个示例。

<div class="entry-content">
    <p><strong>TITLE 1.1</strong></p>
    <div class="item">
        <p><strong>TITLE 1.2</strong></p>
        <p><em>Writer writes:</em></p>
        <p>Article #1</p>
        <p>&nbsp;</p>
    </div>

    <p><strong>TITLE 2.1</strong></p>
    <div class="item">
        <p><strong>TITLE 2.2</strong></p>
        <p><em>Writer writes:</em></p>
        <p>Article #2.1</p>
        <p>Article #2.2</p>
        <p>Article #2.3</p>
    </div>
</div>

JS 应该看起来像

$(document).ready(function(){
    $("#post-60 p strong").click(function(){
        $(this).parent().next('.item').toggle(500);
    });
});

查看更新的 fiddle https://jsfiddle.net/xpxhkh1r/1/

关于jQuery - 仅切换下一个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40510186/

相关文章:

jquery - 确定是否有任何文本跟随 anchor 标记(或 : ':last-child' selector that counts text nodes)

javascript - 动态添加和删除输入

php - 将动态生成的列表中的数据从一个页面传递到另一个页面

javascript - 在下拉 javascript/jquery 上更改图像,在 fiddle 中工作,但在其他地方不行?

css-selectors - 为什么 cypress 无法识别我们是否给出完整的类名

jquery click事件,使用next和prev将列表项滚动到div的顶部

javascript - jquery文件上传进度条不准确

PHP:调用 Javascript 命令

javascript - jQuery 选择没有类或 ID 的元素

jquery - 选择 href 不以某个字符串开头的元素