首页 > 解决方案 > 从多个li中选择同一个孩子

问题描述

我已经从 ul 和 li 列表中构建了表格。我现在想通过更改所有行内 li 的类来切换 li“单元格”的类,但来自多个 div 的同一个子项,以便给出高亮行的样式。

  1. 单击 li 孩子更改所有列表中相同 li 孩子的班级
  2. 在所有列表中的 li 孩子的悬停上更改同一 li 孩子的班级

影响在单击和悬停时突出显示“行”。

为清楚起见,请参阅下面的基本大纲。

我的代码

$("#cell").hover(function() {
  (".cd-features-list li").addClass("cellHover");
});

$("#cell").click(function() {
  (".cd-features-list li").addClass("cellClick");
});
    .cellHover {
  background: #888;
  ) .cellClick {
    background: #111;
    )
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="cd-products-table">
  <div class="features">
    <div class="top-info">Models</div>
    <ul class="cd-features-list">
      <li>Programme Type</li>
      <li>Completion speed</li>
      <li>Visa Coverage</li>
      <li>Investment Type</li>
      <li>Min. Investment</li>
      <li>Family included</li>
      <li>Family entitlements</li>
      <li>PR time frame</li>
      <li>Citizenship time frame</li>
      <li>Annual min. stay</li>
    </ul>
  </div>
  <!-- .features -->

  <div class="cd-products-wrapper">
    <ul class="cd-products-columns">
      <li class="product">
        <div class="top-info">
          <img src="/images/flags/portugal-flag.svg" alt="product image" height="100" width="230">
          <h3>Portugal</h3>
          <br>
          <div class="check"></div>

        </div>
        <!-- .top-info -->

        <ul class="cd-features-list">
          <li>xxxxxxx</li>
          <li class="rate"><span>5/5</span></li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
        </ul>
      </li>
      <!-- .product -->

      <li class="product">
        <div class="top-info">
          <img src="/images/flags/british-flag.svg" alt="product image" height="100" width="230">
          <h3>United Kingdom</h3>
          <br>
          <div class="check"></div>

        </div>
        <!-- .top-info -->

        <ul class="cd-features-list">
          <li>xxxxxxx</li>
          <li class="rate"><span>5/5</span></li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxxs</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>1 xxxxxxx</li>
          <li>3 xxxxxxx</li>
          <li>1 xxxxxxx</li>
        </ul>
      </li>
      <!-- .product -->

      <li class="product">
        <div class="top-info">
          <img src="/images/flags/cypriot-flag.svg" alt="product image" height="100" width="230">
          <h3>Cyprus</h3>
          <br>
          <div class="check"></div>

        </div>
        <!-- .top-info -->

        <ul class="cd-features-list">
          <li>xxxxxxx</li>
          <li class="rate"><span>5/5</span></li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li> xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>1 xxxxxxx</li>
          <li>3 xxxxxxx</li>
          <li>1 xxxxxxx</li>
        </ul>
      </li>
      <!-- .product -->

标签: jquerycss

解决方案


在这里使用这个 jsfiddle

$( ".cd-features-list > li" ).hover(
  function() { 
  var u=$(this).parent('ul');
   $(u).addClass("cellHover");
  }, function() {
   var u=$(this).parent('ul');
   $(u).removeClass("cellHover");
   
  }
);

$( ".cd-features-list li" ).click(function() { 
 var u=$(this).parent('ul');
   $(u).addClass("cellClick");
  }
);
 .cellHover {
  background-color: #666666;
  }
  .cellClick {
    background: #111;
    }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="cd-products-table">
  <div class="features">
    <div class="top-info">Models</div>
    <ul class="cd-features-list">
      <li>Programme Type</li>
      <li>Completion speed</li>
      <li>Visa Coverage</li>
      <li>Investment Type</li>
      <li>Min. Investment</li>
      <li>Family included</li>
      <li>Family entitlements</li>
      <li>PR time frame</li>
      <li>Citizenship time frame</li>
      <li>Annual min. stay</li>
    </ul>
  </div>
  <!-- .features -->

  <div class="cd-products-wrapper">
    <ul class="cd-products-columns">
      <li class="product">
        <div class="top-info">
          <img src="/images/flags/portugal-flag.svg" alt="product image" height="100" width="230">
          <h3>Portugal</h3>
          <br>
          <div class="check"></div>

        </div>
        <!-- .top-info -->

        <ul class="cd-features-list">
          <li>xxxxxxx</li>
          <li class="rate"><span>5/5</span></li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
        </ul>
      </li>
      <!-- .product -->

      <li class="product">
        <div class="top-info">
          <img src="/images/flags/british-flag.svg" alt="product image" height="100" width="230">
          <h3>United Kingdom</h3>
          <br>
          <div class="check"></div>

        </div>
        <!-- .top-info -->

        <ul class="cd-features-list">
          <li>xxxxxxx</li>
          <li class="rate"><span>5/5</span></li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxxs</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>1 xxxxxxx</li>
          <li>3 xxxxxxx</li>
          <li>1 xxxxxxx</li>
        </ul>
      </li>
      <!-- .product -->

      <li class="product">
        <div class="top-info">
          <img src="/images/flags/cypriot-flag.svg" alt="product image" height="100" width="230">
          <h3>Cyprus</h3>
          <br>
          <div class="check"></div>

        </div>
        <!-- .top-info -->

        <ul class="cd-features-list">
          <li>xxxxxxx</li>
          <li class="rate"><span>5/5</span></li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li> xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>xxxxxxx</li>
          <li>1 xxxxxxx</li>
          <li>3 xxxxxxx</li>
          <li>1 xxxxxxx</li>
        </ul>
      </li>


推荐阅读