javascript - 加载并单击时隐藏/显示 div

标签 javascript jquery

我想要做的是在加载时隐藏除 #p0 之外的所有段落。 另外,如果用户单击它的同级跨度,我想显示一个段落,并隐藏所有其他段落

<ul>
   <li>
      <h1>
        <span id="span0">Lorem</span>
        <p id="p0">Lorem ipsum dolor sit amet,</p>
      </h1>
   </li>
   <li>
      <h1>
        <span id="span1">Lorem2</span>
        <p id="p1">Lorem ipsum dolor sit amet,</p>
      </h1>
   </li>
   <li>
      <h1>
        <span id="span2">Lorem3</span>
        <p id="p2">Lorem ipsum dolor sit amet,</p>
      </h1> 
   </li>
...

最佳答案

$('p:not("#p0")').hide();

$('span').on('click',function() {
    $('p').hide();
    $(this).next('p').show();
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

<ul>
   <li>
      <h1>
        <span id="span0">Lorem</span>
        <p id="p0">Lorem ipsum dolor sit amet,</p>
      </h1>
   </li>
   <li>
      <h1>
        <span id="span1">Lorem2</span>
        <p id="p1">Lorem ipsum dolor sit amet,</p>
      </h1>
   </li>
   <li>
      <h1>
        <span id="span2">Lorem3</span>
        <p id="p2">Lorem ipsum dolor sit amet,</p>
      </h1> 
   </li>
 </ul>

如果您希望将其与页面上的其他 p/span 隔离,您可以使用 'prefixed-by' attribute selector (^=) ...

$('p[id^="p"]:not("#p0")').hide();

$('span[id^="span"]').on('click',function() {
    $('p[id^="p"]').hide();
    $(this).next('p[id^="p"]').show();
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

<ul>
   <li>
      <h1>
        <span id="span0">Lorem</span>
        <p id="p0">Lorem ipsum dolor sit amet,</p>
      </h1>
   </li>
   <li>
      <h1>
        <span id="span1">Lorem2</span>
        <p id="p1">Lorem ipsum dolor sit amet,</p>
      </h1>
   </li>
   <li>
      <h1>
        <span id="span2">Lorem3</span>
        <p id="p2">Lorem ipsum dolor sit amet,</p>
      </h1> 
   </li>
 </ul>

关于javascript - 加载并单击时隐藏/显示 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35340389/

相关文章:

javascript - 仅用 2 个 div 查看 6 个 div 的内容

javascript - 如何在某个元素之后将所有元素包装在 div 中? (查询)

JQueryUI Accordion : Headers and an inline block for arranging image/text

javascript - Chrome 中单击复选框时总是调用 div 的事件

javascript - 获取 slideToggle 以展开和显示隐藏内容

javascript - 确定鼠标悬停在元素上时是否有元素 "dragged"

javascript - 我如何在 javascript 代码中包含 php 文件

javascript - 如何使用 JavaScript 将一个小图像嵌入到另一个图像之上并保存?

javascript - X-Editable - 如何使用 ajax 提取表单数据

javascript - 检查 iFrame 内容是否存在